Class HttpConnection
- java.lang.Object
- 
- org.eclipse.jetty.io.AbstractConnection
- 
- org.eclipse.jetty.server.HttpConnection
 
 
- 
- All Implemented Interfaces:
- java.io.Closeable,- java.lang.AutoCloseable,- java.lang.Runnable,- Connection,- Connection.UpgradeFrom,- Connection.UpgradeTo,- WriteFlusher.Listener,- HttpTransport
 
 public class HttpConnection extends AbstractConnection implements java.lang.Runnable, HttpTransport, WriteFlusher.Listener, Connection.UpgradeFrom, Connection.UpgradeTo A Connectionthat handles the HTTP protocol.
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.eclipse.jetty.io.ConnectionConnection.Listener, Connection.UpgradeFrom, Connection.UpgradeTo
 
- 
 - 
Field SummaryFields Modifier and Type Field Description static HttpFieldCONNECTION_CLOSEstatic java.lang.StringUPGRADE_CONNECTION_ATTRIBUTE
 - 
Constructor SummaryConstructors Constructor Description HttpConnection(HttpConfiguration config, Connector connector, EndPoint endPoint, HttpCompliance compliance, boolean recordComplianceViolations)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Deprecated Methods Modifier and Type Method Description voidabort(java.lang.Throwable failure)Aborts this transport.voidasyncReadFillInterested()voidblockingReadFailure(java.lang.Throwable e)voidblockingReadFillInterested()protected booleanfillAndParseForContent()Fill and parse data looking for contentlonggetBytesIn()longgetBytesOut()ConnectorgetConnector()static HttpConnectiongetCurrentConnection()Get the current connection that this thread is dispatched to.HttpGeneratorgetGenerator()HttpChannelgetHttpChannel()HttpCompliancegetHttpCompliance()Deprecated.HttpConfigurationgetHttpConfiguration()longgetMessagesIn()longgetMessagesOut()HttpParsergetParser()java.nio.ByteBuffergetRequestBuffer()ServergetServer()booleanisOptimizedForDirectBuffers()Is the underlying transport optimized for DirectBuffer usagebooleanisPushSupported()booleanisRecordHttpComplianceViolations()booleanisRequestBufferEmpty()protected HttpChannelOverHttpnewHttpChannel()protected HttpGeneratornewHttpGenerator()protected HttpParsernewHttpParser(HttpCompliance compliance)protected HttpParser.RequestHandlernewRequestHandler()voidonClose()Callback method invoked when this connection is closed.voidonCompleted()Called to indicated the end of the current request/response cycle (which may be some time after the last content is sent).voidonFillable()Callback method invoked when the endpoint is ready to be read.protected voidonFillInterestedFailed(java.lang.Throwable cause)Callback method invoked when the endpoint failed to be ready to be read.voidonFlushed(long bytes)Invoked when aWriteFlusherflushed bytes in a non-blocking way, as part of a - possibly larger - write.voidonOpen()Callback method invoked when this connection is opened.protected booleanonReadTimeout(java.lang.Throwable timeout)Callback method invoked when the endpoint failed to be ready to be read after a timeoutjava.nio.ByteBufferonUpgradeFrom()Invoked during anupgradeto produce a buffer containing bytes that have not been consumed by this connection, and that must be consumed by the upgrade-to connection.voidonUpgradeTo(java.nio.ByteBuffer buffer)Invoked during anupgradeto receive a buffer containing bytes that have not been consumed by the upgrade-from connection, and that must be consumed by this connection.voidpush(MetaData.Request request)voidrun()voidsend(MetaData.Response info, boolean head, java.nio.ByteBuffer content, boolean lastContent, Callback callback)Asynchronous call to send a response (or part) over the transportprotected static HttpConnectionsetCurrentConnection(HttpConnection connection)java.lang.StringtoConnectionString()- 
Methods inherited from class org.eclipse.jetty.io.AbstractConnectionaddListener, close, failedCallback, fillInterested, getCreatedTimeStamp, getEndPoint, getExecutor, getInputBufferSize, isFillInterested, onIdleExpired, removeListener, setInputBufferSize, toString, tryFillInterested, tryFillInterested
 
- 
 
- 
- 
- 
Field Detail- 
CONNECTION_CLOSEpublic static final HttpField CONNECTION_CLOSE 
 - 
UPGRADE_CONNECTION_ATTRIBUTEpublic static final java.lang.String UPGRADE_CONNECTION_ATTRIBUTE - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
HttpConnectionpublic HttpConnection(HttpConfiguration config, Connector connector, EndPoint endPoint, HttpCompliance compliance, boolean recordComplianceViolations) 
 
- 
 - 
Method Detail- 
getCurrentConnectionpublic static HttpConnection getCurrentConnection() Get the current connection that this thread is dispatched to. Note that a thread may be processing a request asynchronously and thus not be dispatched to the connection.- Returns:
- the current HttpConnection or null
- See Also:
- for a more general way to access the HttpConnection
 
 - 
setCurrentConnectionprotected static HttpConnection setCurrentConnection(HttpConnection connection) 
 - 
getHttpCompliance@Deprecated public HttpCompliance getHttpCompliance() Deprecated.
 - 
getHttpConfigurationpublic HttpConfiguration getHttpConfiguration() 
 - 
isRecordHttpComplianceViolationspublic boolean isRecordHttpComplianceViolations() 
 - 
newHttpGeneratorprotected HttpGenerator newHttpGenerator() 
 - 
newHttpChannelprotected HttpChannelOverHttp newHttpChannel() 
 - 
newHttpParserprotected HttpParser newHttpParser(HttpCompliance compliance) 
 - 
newRequestHandlerprotected HttpParser.RequestHandler newRequestHandler() 
 - 
getServerpublic Server getServer() 
 - 
getConnectorpublic Connector getConnector() 
 - 
getHttpChannelpublic HttpChannel getHttpChannel() 
 - 
getParserpublic HttpParser getParser() 
 - 
getGeneratorpublic HttpGenerator getGenerator() 
 - 
isOptimizedForDirectBufferspublic boolean isOptimizedForDirectBuffers() Description copied from interface:HttpTransportIs the underlying transport optimized for DirectBuffer usage- Specified by:
- isOptimizedForDirectBuffersin interface- HttpTransport
- Returns:
- True if direct buffers can be used optimally.
 
 - 
getMessagesInpublic long getMessagesIn() - Specified by:
- getMessagesInin interface- Connection
- Overrides:
- getMessagesInin class- AbstractConnection
 
 - 
getMessagesOutpublic long getMessagesOut() - Specified by:
- getMessagesOutin interface- Connection
- Overrides:
- getMessagesOutin class- AbstractConnection
 
 - 
onUpgradeFrompublic java.nio.ByteBuffer onUpgradeFrom() Description copied from interface:Connection.UpgradeFromInvoked during an upgradeto produce a buffer containing bytes that have not been consumed by this connection, and that must be consumed by the upgrade-to connection.- Specified by:
- onUpgradeFromin interface- Connection.UpgradeFrom
- Returns:
- a buffer of unconsumed bytes to pass to the upgrade-to connection. The buffer does not belong to any pool and should be discarded after having consumed its bytes. The returned buffer may be null if there are no unconsumed bytes.
 
 - 
onUpgradeTopublic void onUpgradeTo(java.nio.ByteBuffer buffer) Description copied from interface:Connection.UpgradeToInvoked during an upgradeto receive a buffer containing bytes that have not been consumed by the upgrade-from connection, and that must be consumed by this connection.- Specified by:
- onUpgradeToin interface- Connection.UpgradeTo
- Parameters:
- buffer- a non-null buffer of unconsumed bytes received from the upgrade-from connection. The buffer does not belong to any pool and should be discarded after having consumed its bytes.
 
 - 
onFlushedpublic void onFlushed(long bytes) throws java.io.IOExceptionDescription copied from interface:WriteFlusher.ListenerInvoked when a WriteFlusherflushed bytes in a non-blocking way, as part of a - possibly larger - write.This method may be invoked multiple times, for example when writing a large buffer: a first flush of bytes, then the connection became TCP congested, and a subsequent flush of bytes when the connection became writable again. This method is never invoked concurrently, but may be invoked by different threads, so implementations may not rely on thread-local variables. Implementations may throw an IOExceptionto signal that the write should fail, for example if the implementation enforces a minimum data rate.- Specified by:
- onFlushedin interface- WriteFlusher.Listener
- Parameters:
- bytes- the number of bytes flushed
- Throws:
- java.io.IOException- if the write should fail
 
 - 
getRequestBufferpublic java.nio.ByteBuffer getRequestBuffer() 
 - 
isRequestBufferEmptypublic boolean isRequestBufferEmpty() 
 - 
onFillablepublic void onFillable() Description copied from class:AbstractConnectionCallback method invoked when the endpoint is ready to be read. - Specified by:
- onFillablein class- AbstractConnection
- See Also:
- AbstractConnection.fillInterested()
 
 - 
fillAndParseForContentprotected boolean fillAndParseForContent() Fill and parse data looking for content- Returns:
- true if an HttpParser.RequestHandlermethod was called and it returned true;
 
 - 
onCompletedpublic void onCompleted() Description copied from interface:HttpTransportCalled to indicated the end of the current request/response cycle (which may be some time after the last content is sent).- Specified by:
- onCompletedin interface- HttpTransport
 
 - 
onReadTimeoutprotected boolean onReadTimeout(java.lang.Throwable timeout) Description copied from class:AbstractConnectionCallback method invoked when the endpoint failed to be ready to be read after a timeout - Overrides:
- onReadTimeoutin class- AbstractConnection
- Parameters:
- timeout- the cause of the read timeout
- Returns:
- true to signal that the endpoint must be closed, false to keep the endpoint open
 
 - 
onFillInterestedFailedprotected void onFillInterestedFailed(java.lang.Throwable cause) Description copied from class:AbstractConnectionCallback method invoked when the endpoint failed to be ready to be read. - Overrides:
- onFillInterestedFailedin class- AbstractConnection
- Parameters:
- cause- the exception that caused the failure
 
 - 
onOpenpublic void onOpen() Description copied from interface:ConnectionCallback method invoked when this connection is opened. Creators of the connection implementation are responsible for calling this method. - Specified by:
- onOpenin interface- Connection
- Overrides:
- onOpenin class- AbstractConnection
 
 - 
onClosepublic void onClose() Description copied from interface:ConnectionCallback method invoked when this connection is closed. Creators of the connection implementation are responsible for calling this method. - Specified by:
- onClosein interface- Connection
- Overrides:
- onClosein class- AbstractConnection
 
 - 
runpublic void run() - Specified by:
- runin interface- java.lang.Runnable
 
 - 
sendpublic void send(MetaData.Response info, boolean head, java.nio.ByteBuffer content, boolean lastContent, Callback callback) Description copied from interface:HttpTransportAsynchronous call to send a response (or part) over the transport- Specified by:
- sendin interface- HttpTransport
- Parameters:
- info- The header info to send, or null if just sending more data. The first call to send for a response must have a non null info.
- head- True if the response if for a HEAD request (and the data should not be sent).
- content- A buffer of content to be sent.
- lastContent- True if the content is the last content for the current response.
- callback- The Callback instance that success or failure of the send is notified on
 
 - 
abortpublic void abort(java.lang.Throwable failure) Description copied from interface:HttpTransportAborts this transport.This method should terminate the transport in a way that can indicate an abnormal response to the client, for example by abruptly close the connection. This method is called when an error response needs to be sent, but the response is already committed, or when a write failure is detected. If abort is called, HttpTransport.onCompleted()is not called- Specified by:
- abortin interface- HttpTransport
- Parameters:
- failure- the failure that caused the abort.
 
 - 
isPushSupportedpublic boolean isPushSupported() - Specified by:
- isPushSupportedin interface- HttpTransport
- Returns:
- true if responses can be pushed over this transport
 
 - 
pushpublic void push(MetaData.Request request) - Specified by:
- pushin interface- HttpTransport
- Parameters:
- request- A request to use as the basis for generating a pushed response.
 
 - 
asyncReadFillInterestedpublic void asyncReadFillInterested() 
 - 
blockingReadFillInterestedpublic void blockingReadFillInterested() 
 - 
blockingReadFailurepublic void blockingReadFailure(java.lang.Throwable e) 
 - 
getBytesInpublic long getBytesIn() - Specified by:
- getBytesInin interface- Connection
- Overrides:
- getBytesInin class- AbstractConnection
 
 - 
getBytesOutpublic long getBytesOut() - Specified by:
- getBytesOutin interface- Connection
- Overrides:
- getBytesOutin class- AbstractConnection
 
 - 
toConnectionStringpublic java.lang.String toConnectionString() - Overrides:
- toConnectionStringin class- AbstractConnection
 
 
- 
 
-