Class FixedLengthDecodingState
java.lang.Object
org.apache.mina.filter.codec.statemachine.FixedLengthDecodingState
- All Implemented Interfaces:
DecodingState
DecodingState which consumes all received bytes until a configured
number of read bytes has been reached. Please note that this state can
produce a buffer with less data than the configured length if the associated
session has been closed unexpectedly.-
Field Summary
Fields -
Constructor Summary
ConstructorsConstructorDescriptionFixedLengthDecodingState(int length) Constructs a new instance using the specified decode length. -
Method Summary
Modifier and TypeMethodDescriptiondecode(IoBuffer in, ProtocolDecoderOutput out) Invoked when data is available for this state.protected abstract DecodingStatefinishDecode(IoBuffer product, ProtocolDecoderOutput out) Invoked when this state has consumed the configured number of bytes.Invoked when the associatedIoSessionis closed.
-
Field Details
-
length
private final int length -
buffer
-
-
Constructor Details
-
FixedLengthDecodingState
public FixedLengthDecodingState(int length) Constructs a new instance using the specified decode length.- Parameters:
length- the number of bytes to read.
-
-
Method Details
-
decode
Invoked when data is available for this state.- Specified by:
decodein interfaceDecodingState- Parameters:
in- the data to be decoded.out- used to write decoded objects.- Returns:
- the next state if a state transition was triggered (use
thisfor loop transitions) ornullif the state machine has reached its end. - Throws:
Exception- if the read data violated protocol specification.
-
finishDecode
Invoked when the associatedIoSessionis closed. This method is useful when you deal with protocols which don't specify the length of a message (e.g. HTTP responses withoutcontent-lengthheader). Implement this method to process the remaining data thatDecodingState.decode(IoBuffer, ProtocolDecoderOutput)method didn't process completely.- Specified by:
finishDecodein interfaceDecodingState- Parameters:
out- used to write decoded objects.- Returns:
- the next state if a state transition was triggered (use
thisfor loop transitions) ornullif the state machine has reached its end. - Throws:
Exception- if the read data violated protocol specification.
-
finishDecode
protected abstract DecodingState finishDecode(IoBuffer product, ProtocolDecoderOutput out) throws Exception Invoked when this state has consumed the configured number of bytes.- Parameters:
product- the data.out- the currentProtocolDecoderOutputused to write decoded messages.- Returns:
- the next state if a state transition was triggered (use
thisfor loop transitions) ornullif the state machine has reached its end. - Throws:
Exception- if the read data violated protocol specification.
-