Package org.apache.coyote.ajp
Class AjpMessage
- java.lang.Object
-
- org.apache.coyote.ajp.AjpMessage
-
public class AjpMessage extends java.lang.Object
A single packet for communication between the web server and the container. Designed to be reused many times with no creation of garbage. Understands the format of data types for these packets. Can be used (somewhat confusingly) for both incoming and outgoing packets.- Author:
- Henri Gomez, Dan Milstein, Keith Wannamaker, Kevin Seguin, Costin Manolache
-
-
Field Summary
Fields Modifier and Type Field Description protected byte[]
buf
Fixed size buffer.protected int
len
This actually means different things depending on whether the packet is read or write.protected int
pos
The current read or write position in the buffer.protected static StringManager
sm
The string manager for this package.
-
Constructor Summary
Constructors Constructor Description AjpMessage(int packetSize)
-
Method Summary
All Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description void
appendByte(int val)
Append a byte (1 byte) to the message.void
appendByteChunk(ByteChunk bc)
Write a ByteChunk out at the current write position.void
appendBytes(byte[] b, int off, int numBytes)
Copy a chunk of bytes into the packet, starting at the current write position.void
appendBytes(java.nio.ByteBuffer b)
Copy a chunk of bytes into the packet, starting at the current write position.void
appendBytes(MessageBytes mb)
Write a MessageBytes out at the current write position.void
appendInt(int val)
Add a short integer (2 bytes) to the message.void
end()
For a packet to be sent to the web server, finish the process of accumulating data and write the length of the data payload into the header.void
getBodyBytes(MessageBytes mb)
byte[]
getBuffer()
Return the underlying byte buffer.byte
getByte()
void
getBytes(MessageBytes mb)
int
getInt()
Read an integer from packet, and advance the read position past it.int
getLen()
Return the current message length.int
getLongInt()
Read a 32 bits integer from packet, and advance the read position past it.protected static java.lang.String
hex(int x)
protected static java.lang.String
hexLine(byte[] buf, int start, int len)
int
peekInt()
int
processHeader(boolean toContainer)
void
reset()
Prepare this packet for accumulating a message from the container to the web server.
-
-
-
Field Detail
-
sm
protected static final StringManager sm
The string manager for this package.
-
buf
protected final byte[] buf
Fixed size buffer.
-
pos
protected int pos
The current read or write position in the buffer.
-
len
protected int len
This actually means different things depending on whether the packet is read or write. For read, it's the length of the payload (excluding the header). For write, it's the length of the packet as a whole (counting the header). Oh, well.
-
-
Method Detail
-
reset
public void reset()
Prepare this packet for accumulating a message from the container to the web server. Set the write position to just after the header (but leave the length unwritten, because it is as yet unknown).
-
end
public void end()
For a packet to be sent to the web server, finish the process of accumulating data and write the length of the data payload into the header.
-
getBuffer
public byte[] getBuffer()
Return the underlying byte buffer.- Returns:
- The buffer
-
getLen
public int getLen()
Return the current message length.- Returns:
- For read, it's the length of the payload (excluding the header). For write, it's the length of the packet as a whole (counting the header).
-
appendInt
public void appendInt(int val)
Add a short integer (2 bytes) to the message.- Parameters:
val
- The integer to append
-
appendByte
public void appendByte(int val)
Append a byte (1 byte) to the message.- Parameters:
val
- The byte value to append
-
appendBytes
public void appendBytes(MessageBytes mb)
Write a MessageBytes out at the current write position. A null MessageBytes is encoded as a string with length 0.- Parameters:
mb
- The data to write
-
appendByteChunk
public void appendByteChunk(ByteChunk bc)
Write a ByteChunk out at the current write position. A null ByteChunk is encoded as a string with length 0.- Parameters:
bc
- The data to write
-
appendBytes
public void appendBytes(byte[] b, int off, int numBytes)
Copy a chunk of bytes into the packet, starting at the current write position. The chunk of bytes is encoded with the length in two bytes first, then the data itself, and finally a terminating \0 (which is not included in the encoded length).- Parameters:
b
- The array from which to copy bytes.off
- The offset into the array at which to start copyingnumBytes
- The number of bytes to copy.
-
appendBytes
public void appendBytes(java.nio.ByteBuffer b)
Copy a chunk of bytes into the packet, starting at the current write position. The chunk of bytes is encoded with the length in two bytes first, then the data itself, and finally a terminating \0 (which is not included in the encoded length).- Parameters:
b
- The ByteBuffer from which to copy bytes.
-
getInt
public int getInt()
Read an integer from packet, and advance the read position past it. Integers are encoded as two unsigned bytes with the high-order byte first, and, as far as I can tell, in little-endian order within each byte.- Returns:
- The integer value read from the message
-
peekInt
public int peekInt()
-
getByte
public byte getByte()
-
getBytes
public void getBytes(MessageBytes mb)
-
getBodyBytes
public void getBodyBytes(MessageBytes mb)
-
getLongInt
public int getLongInt()
Read a 32 bits integer from packet, and advance the read position past it. Integers are encoded as four unsigned bytes with the high-order byte first, and, as far as I can tell, in little-endian order within each byte.- Returns:
- The long value read from the message
-
processHeader
public int processHeader(boolean toContainer)
-
hexLine
protected static java.lang.String hexLine(byte[] buf, int start, int len)
-
hex
protected static java.lang.String hex(int x)
-
-