@UnstableApi public class InboundHttp2ToHttpAdapter extends Http2EventAdapter
 See HttpToHttp2ConnectionHandler to get translation from HTTP/1.x objects to HTTP/2 frames for writes.
| 限定符和类型 | 字段和说明 | 
|---|---|
| protected Http2Connection | connection | 
| protected boolean | validateHttpHeaders | 
| 限定符 | 构造器和说明 | 
|---|---|
| protected  | InboundHttp2ToHttpAdapter(Http2Connection connection,
                         int maxContentLength,
                         boolean validateHttpHeaders,
                         boolean propagateSettings) | 
| 限定符和类型 | 方法和说明 | 
|---|---|
| protected void | fireChannelRead(ChannelHandlerContext ctx,
               FullHttpMessage msg,
               boolean release,
               Http2Stream stream)Set final headers and fire a channel read event | 
| protected FullHttpMessage | getMessage(Http2Stream stream)Get the  FullHttpMessageassociated withstream. | 
| protected FullHttpMessage | newMessage(Http2Stream stream,
          Http2Headers headers,
          boolean validateHttpHeaders,
          ByteBufAllocator alloc)Create a new  FullHttpMessagebased upon the current connection parameters | 
| int | onDataRead(ChannelHandlerContext ctx,
          int streamId,
          ByteBuf data,
          int padding,
          boolean endOfStream)Handles an inbound  DATAframe. | 
| void | onHeadersRead(ChannelHandlerContext ctx,
             int streamId,
             Http2Headers headers,
             int padding,
             boolean endOfStream)Handles an inbound  HEADERSframe. | 
| void | onHeadersRead(ChannelHandlerContext ctx,
             int streamId,
             Http2Headers headers,
             int streamDependency,
             short weight,
             boolean exclusive,
             int padding,
             boolean endOfStream)Handles an inbound  HEADERSframe with priority information specified. | 
| void | onPushPromiseRead(ChannelHandlerContext ctx,
                 int streamId,
                 int promisedStreamId,
                 Http2Headers headers,
                 int padding)Handles an inbound  PUSH_PROMISEframe. | 
| void | onRstStreamRead(ChannelHandlerContext ctx,
               int streamId,
               long errorCode)Handles an inbound  RST_STREAMframe. | 
| protected void | onRstStreamRead(Http2Stream stream,
               FullHttpMessage msg)Called if a  RST_STREAMis received but we have some data for that stream. | 
| void | onSettingsRead(ChannelHandlerContext ctx,
              Http2Settings settings)Handles an inbound  SETTINGSframe. | 
| void | onStreamRemoved(Http2Stream stream)Notifies the listener that the given stream has now been removed from the connection and
 will no longer be returned via  Http2Connection.stream(int). | 
| protected FullHttpMessage | processHeadersBegin(ChannelHandlerContext ctx,
                   Http2Stream stream,
                   Http2Headers headers,
                   boolean endOfStream,
                   boolean allowAppend,
                   boolean appendToTrailer)Provides translation between HTTP/2 and HTTP header objects while ensuring the stream
 is in a valid state for additional headers. | 
| protected void | putMessage(Http2Stream stream,
          FullHttpMessage message)Make  messagebe the state associated withstream. | 
| protected void | removeMessage(Http2Stream stream,
             boolean release)The stream is out of scope for the HTTP message flow and will no longer be tracked | 
onGoAwayRead, onGoAwayReceived, onGoAwaySent, onPingAckRead, onPingRead, onPriorityRead, onSettingsAckRead, onStreamActive, onStreamAdded, onStreamClosed, onStreamHalfClosed, onUnknownFrame, onWindowUpdateReadprotected final Http2Connection connection
protected final boolean validateHttpHeaders
protected InboundHttp2ToHttpAdapter(Http2Connection connection, int maxContentLength, boolean validateHttpHeaders, boolean propagateSettings)
protected final void removeMessage(Http2Stream stream, boolean release)
stream - The stream to remove associated state withrelease - true to call release on the value if it is present. false to not call release.protected final FullHttpMessage getMessage(Http2Stream stream)
FullHttpMessage associated with stream.stream - The stream to get the associated state fromFullHttpMessage associated with stream.protected final void putMessage(Http2Stream stream, FullHttpMessage message)
message be the state associated with stream.stream - The stream which message is associated with.message - The message which contains the HTTP semantics.public void onStreamRemoved(Http2Stream stream)
Http2Connection.ListenerHttp2Connection.stream(int). The connection may
 maintain inactive streams for some time before removing them.
 
 If a RuntimeException is thrown it will be logged and not propagated.
 Throwing from this method is not supported and is considered a programming error.
onStreamRemoved 在接口中 Http2Connection.ListeneronStreamRemoved 在类中 Http2EventAdapterprotected void fireChannelRead(ChannelHandlerContext ctx, FullHttpMessage msg, boolean release, Http2Stream stream)
ctx - The context to fire the event onmsg - The message to sendrelease - true to call release on the value if it is present. false to not call release.stream - the stream of the message which is being firedprotected FullHttpMessage newMessage(Http2Stream stream, Http2Headers headers, boolean validateHttpHeaders, ByteBufAllocator alloc) throws Http2Exception
FullHttpMessage based upon the current connection parametersstream - The stream to create a message forheaders - The headers associated with streamvalidateHttpHeaders - true to validate HTTP headers in the http-codecfalse not to validate HTTP headers in the http-codecalloc - The ByteBufAllocator to use to generate the content of the messageHttp2Exception - If there is an error when creating FullHttpMessage from
                        Http2Stream and Http2Headersprotected FullHttpMessage processHeadersBegin(ChannelHandlerContext ctx, Http2Stream stream, Http2Headers headers, boolean endOfStream, boolean allowAppend, boolean appendToTrailer) throws Http2Exception
ctx - The context for which this message has been received.
 Used to send informational header if detected.stream - The stream the headers apply toheaders - The headers to processendOfStream - true if the stream has received the end of stream flagallowAppend - true if headers will be appended if the stream already exists.false and the stream already exists this method returns null.appendToTrailer - true if a message stream already exists then the headers
 should be added to the trailing headers.false then appends will be done to the initial headers.stream. null if
         allowAppend is false and the stream already exists.Http2Exception - If the stream id is not in the correct state to process the headers requestpublic int onDataRead(ChannelHandlerContext ctx, int streamId, ByteBuf data, int padding, boolean endOfStream) throws Http2Exception
Http2FrameListenerDATA frame.onDataRead 在接口中 Http2FrameListeneronDataRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.streamId - the subject stream for the frame.data - payload buffer for the frame. This buffer will be released by the codec.padding - additional bytes that should be added to obscure the true content size. Must be between 0 and
                256 (inclusive).endOfStream - Indicates whether this is the last frame to be sent from the remote endpoint for this stream.WINDOW_UPDATE). Returning a value equal to the length of data + padding will effectively
 opt-out of application-level flow control for this frame. Returning a value less than the length of data
 + padding will defer the returning of the processed bytes, which the application must later return via
 Http2LocalFlowController.consumeBytes(Http2Stream, int). The returned value must
 be >= 0 and <= data.readableBytes() + padding.Http2Exceptionpublic void onHeadersRead(ChannelHandlerContext ctx, int streamId, Http2Headers headers, int padding, boolean endOfStream) throws Http2Exception
Http2FrameListenerHEADERS frame.
 
 Only one of the following methods will be called for each HEADERS frame sequence.
 One will be called when the END_HEADERS flag has been received.
 
Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, boolean)Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, short, boolean, int, boolean)Http2FrameListener.onPushPromiseRead(ChannelHandlerContext, int, int, Http2Headers, int)
 To say it another way; the Http2Headers will contain all of the headers
 for the current message exchange step (additional queuing is not necessary).
onHeadersRead 在接口中 Http2FrameListeneronHeadersRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.streamId - the subject stream for the frame.headers - the received headers.padding - additional bytes that should be added to obscure the true content size. Must be between 0 and
                256 (inclusive).endOfStream - Indicates whether this is the last frame to be sent from the remote endpoint
            for this stream.Http2Exceptionpublic void onHeadersRead(ChannelHandlerContext ctx, int streamId, Http2Headers headers, int streamDependency, short weight, boolean exclusive, int padding, boolean endOfStream) throws Http2Exception
Http2FrameListenerHEADERS frame with priority information specified.
 Only called if END_HEADERS encountered.
 
 Only one of the following methods will be called for each HEADERS frame sequence.
 One will be called when the END_HEADERS flag has been received.
 
Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, boolean)Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, short, boolean, int, boolean)Http2FrameListener.onPushPromiseRead(ChannelHandlerContext, int, int, Http2Headers, int)
 To say it another way; the Http2Headers will contain all of the headers
 for the current message exchange step (additional queuing is not necessary).
onHeadersRead 在接口中 Http2FrameListeneronHeadersRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.streamId - the subject stream for the frame.headers - the received headers.streamDependency - the stream on which this stream depends, or 0 if dependent on the
            connection.weight - the new weight for the stream.exclusive - whether or not the stream should be the exclusive dependent of its parent.padding - additional bytes that should be added to obscure the true content size. Must be between 0 and
                256 (inclusive).endOfStream - Indicates whether this is the last frame to be sent from the remote endpoint
            for this stream.Http2Exceptionpublic void onRstStreamRead(ChannelHandlerContext ctx, int streamId, long errorCode) throws Http2Exception
Http2FrameListenerRST_STREAM frame.onRstStreamRead 在接口中 Http2FrameListeneronRstStreamRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.streamId - the stream that is terminating.errorCode - the error code identifying the type of failure.Http2Exceptionpublic void onPushPromiseRead(ChannelHandlerContext ctx, int streamId, int promisedStreamId, Http2Headers headers, int padding) throws Http2Exception
Http2FrameListenerPUSH_PROMISE frame. Only called if END_HEADERS encountered.
 Promised requests MUST be authoritative, cacheable, and safe. See [RFC 7540], Section 8.2.
 Only one of the following methods will be called for each HEADERS frame sequence.
 One will be called when the END_HEADERS flag has been received.
 
Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, boolean)Http2FrameListener.onHeadersRead(ChannelHandlerContext, int, Http2Headers, int, short, boolean, int, boolean)Http2FrameListener.onPushPromiseRead(ChannelHandlerContext, int, int, Http2Headers, int)
 To say it another way; the Http2Headers will contain all of the headers
 for the current message exchange step (additional queuing is not necessary).
onPushPromiseRead 在接口中 Http2FrameListeneronPushPromiseRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.streamId - the stream the frame was sent on.promisedStreamId - the ID of the promised stream.headers - the received headers.padding - additional bytes that should be added to obscure the true content size. Must be between 0 and
                256 (inclusive).Http2Exceptionpublic void onSettingsRead(ChannelHandlerContext ctx, Http2Settings settings) throws Http2Exception
Http2FrameListenerSETTINGS frame.onSettingsRead 在接口中 Http2FrameListeneronSettingsRead 在类中 Http2EventAdapterctx - the context from the handler where the frame was read.settings - the settings received from the remote endpoint.Http2Exceptionprotected void onRstStreamRead(Http2Stream stream, FullHttpMessage msg)
RST_STREAM is received but we have some data for that stream.