本文整理汇总了Java中java.io.ObjectStreamConstants.TC_BLOCKDATA属性的典型用法代码示例。如果您正苦于以下问题:Java ObjectStreamConstants.TC_BLOCKDATA属性的具体用法?Java ObjectStreamConstants.TC_BLOCKDATA怎么用?Java ObjectStreamConstants.TC_BLOCKDATA使用的例子?那么, 这里精选的属性代码示例或许可以为您提供帮助。您也可以进一步了解该属性所在类java.io.ObjectStreamConstants
的用法示例。
在下文中一共展示了ObjectStreamConstants.TC_BLOCKDATA属性的4个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Java代码示例。
示例1: read_blockdata
public BlockData read_blockdata( byte tc, DataInputStream dis ) throws IOException
{
int size;
if ( tc == ObjectStreamConstants.TC_BLOCKDATA ) {
size = dis.readUnsignedByte();
}
else if ( tc == ObjectStreamConstants.TC_BLOCKDATALONG ) {
size = dis.readInt();
}
else {
throw new IOException( "invalid tc value for blockdata: " + hex( tc ) );
}
if ( size < 0 ) {
throw new IOException( "invalid value for blockdata size: " + size );
}
byte[] b = new byte[size];
dis.readFully( b );
debug( "read blockdata of size " + size );
return new BlockData( b );
}
示例2: handleObjectAnnotation
/*******************
* Handle an objectAnnotation element, extracting the object endpoint
* details if found.
*
* @param obj The RMIObject to populate with class names.
* @param dataStack The remaining data in the ReplyData packet.
******************/
private void handleObjectAnnotation(RMIObject obj, LinkedList<Byte> dataStack) throws BaRMIeInvalidReplyDataPacketException {
byte b;
//Read elements from the stream until a TC_ENDBLOCKDATA element is read
while((b = dataStack.pop()) != ObjectStreamConstants.TC_ENDBLOCKDATA) {
//Handle the annotation
switch(b) {
//Look for object endpoint details in block data elements
case ObjectStreamConstants.TC_BLOCKDATA:
//Push the block type back on to the stack and extract endpoint details if found
dataStack.push(ObjectStreamConstants.TC_BLOCKDATA);
this.extractObjectEndpointFromBlockData(obj, dataStack);
break;
//Skip over object annotations
case ObjectStreamConstants.TC_OBJECT:
this.handleNewObjectElement(obj, dataStack);
break;
//Ignore null annotations...
case ObjectStreamConstants.TC_NULL:
break;
//Unknown annotation type
default:
throw new BaRMIeInvalidReplyDataPacketException("Unknown classAnnotation element type (0x" + String.format("%02x", b) + ").");
}
}
}
示例3: read_Content
/**
* <p>
* Read the next object corresponding to the spec grammar rule "content", and return
* an object of type content.
* </p>
*
* <p>
* Usually, there is a 1:1 mapping of content items and returned instances. The
* one case where this isn't true is when an exception is embedded inside another
* object. When this is encountered, only the serialized exception object is
* returned; it's up to the caller to backtrack in order to gather any data from the
* object that was being serialized when the exception was thrown.
* </p>
*
* @param tc
* the last byte read from the stream; it must be one of the TC_* values
* within ObjectStreamConstants.*
* @param dis
* the DataInputStream to read from
* @param blockdata
* whether or not to read TC_BLOCKDATA (this is the difference
* between spec rules "object" and "content").
* @return an object representing the last read item from the stream
* @throws IOException
* when a validity or I/O error occurs while reading
*/
public Content read_Content( byte tc, DataInputStream dis, boolean blockdata ) throws IOException
{
try {
switch ( tc ) {
case ObjectStreamConstants.TC_OBJECT:
return read_newObject( dis );
case ObjectStreamConstants.TC_CLASS:
return read_newClass( dis );
case ObjectStreamConstants.TC_ARRAY:
return read_newArray( dis );
case ObjectStreamConstants.TC_STRING:
case ObjectStreamConstants.TC_LONGSTRING:
return read_newString( tc, dis );
case ObjectStreamConstants.TC_ENUM:
return read_newEnum( dis );
case ObjectStreamConstants.TC_CLASSDESC:
case ObjectStreamConstants.TC_PROXYCLASSDESC:
return handle_newClassDesc( tc, dis );
case ObjectStreamConstants.TC_REFERENCE:
return read_prevObject( dis );
case ObjectStreamConstants.TC_NULL:
return null;
case ObjectStreamConstants.TC_EXCEPTION:
return read_Exception( dis );
case ObjectStreamConstants.TC_BLOCKDATA:
case ObjectStreamConstants.TC_BLOCKDATALONG:
if ( blockdata == false ) {
throw new IOException( "got a blockdata TC_*, but not allowed here: " + hex( tc ) );
}
return read_blockdata( tc, dis );
default:
throw new IOException( "unknown content tc byte in stream: " + hex( tc ) );
}
}
catch ( ReadException ere ) {
return ere.getExceptionObject();
}
}
示例4: extractObjectDetails
/*******************
* Extract object details from a ReplyData that was captured through the
* RMI registry proxy.
*
* @param objName The object name bound to the RMI registry for which data is being extracted.
* @param packetBytes The ReplyData captured from the RMI registry which contains the remote object description.
* @return An RMIObject describing the remote object.
******************/
public RMIObject extractObjectDetails(String objName, ArrayList<Byte> packetBytes) {
LinkedList<Byte> dataStack;
RMIObject obj;
byte b;
int i;
//Create the RMIObject with the given object name
obj = new RMIObject(objName);
//Copy the given buffer into a stack for parsing
dataStack = new LinkedList<Byte>();
dataStack.addAll(packetBytes);
//Set the 'recordClasses' flag to true so that class descriptions are added to the object description
this._recordClasses = true;
//Start parsing the object data
try {
//Validate the RMI packet type byte
if(dataStack.peek() != 0x51) { throw new BaRMIeInvalidReplyDataPacketException("The data buffer begins with 0x" + String.format("%02x", dataStack.peek()) + ", which is not a ReplyData packet (0x51 expected)."); }
dataStack.pop();
//Validate the serialisation header
if(dataStack.pop() != (byte)0xac || dataStack.pop() != (byte)0xed) { throw new BaRMIeInvalidReplyDataPacketException("The data buffer does not contain the serialisation magic number data."); }
//Validate the serialisation stream version
if(dataStack.pop() != 0x00 || dataStack.pop() != 0x05) { throw new BaRMIeInvalidReplyDataPacketException("The data buffer does not contain version 5 serialisation data."); }
//Parse the serialisation stream elements to extract class names, annotations, and endpoint details
while(dataStack.size() > 0) {
//Get the type of the next stream element
b = dataStack.pop();
//Process the element accordingly
switch(b) {
//Skip over top-level block data elements
case ObjectStreamConstants.TC_BLOCKDATA:
//Read the block length
b = dataStack.pop();
//Skip over the block bytes
for(i = 0; i < b; ++i) {
dataStack.pop();
}
break;
//Process the returned RMI object
case ObjectStreamConstants.TC_OBJECT:
this.handleNewObjectElement(obj, dataStack);
break;
//Unknown top-level stream element type
default:
throw new BaRMIeInvalidReplyDataPacketException("Unknown serialisation stream element (0x" + String.format("%02x", b) + ").");
}
}
} catch(Exception e) {
//Something went wrong, store the exception in the object element so it can be reviewed
obj.setParsingException(e);
}
//Return the RMIObject
return obj;
}