Class AjpProcessor

All Implemented Interfaces:
ActionHook, Processor

public class AjpProcessor extends AbstractProcessor
AJP Processor implementation.
  • Field Details

    • ajpFlush

      protected boolean ajpFlush
      Send AJP flush packet when flushing. An flush packet is a zero byte AJP13 SEND_BODY_CHUNK packet. mod_jk and mod_proxy_ajp interprete this as a request to flush data to the client. AJP always does flush at the and of the response, so if it is not important, that the packets get streamed up to the client, do not use extra flush packets. For compatibility and to stay on the safe side, flush packets are enabled by default.
  • Constructor Details

    • AjpProcessor

      public AjpProcessor(int packetSize, AbstractEndpoint<?,?> endpoint)
  • Method Details

    • getAjpFlush

      public boolean getAjpFlush()
    • setAjpFlush

      public void setAjpFlush(boolean ajpFlush)
    • getKeepAliveTimeout

      public int getKeepAliveTimeout()
    • setKeepAliveTimeout

      public void setKeepAliveTimeout(int timeout)
    • getTomcatAuthentication

      public boolean getTomcatAuthentication()
    • setTomcatAuthentication

      public void setTomcatAuthentication(boolean tomcatAuthentication)
    • getTomcatAuthorization

      public boolean getTomcatAuthorization()
    • setTomcatAuthorization

      public void setTomcatAuthorization(boolean tomcatAuthorization)
    • setRequiredSecret

      @Deprecated public void setRequiredSecret(String requiredSecret)
      Deprecated.
    • setSecret

      public void setSecret(String secret)
    • getClientCertProvider

      public String getClientCertProvider()
    • setClientCertProvider

      public void setClientCertProvider(String clientCertProvider)
    • setAllowedRequestAttributesPattern

      public void setAllowedRequestAttributesPattern(Pattern allowedRequestAttributesPattern)
    • flushBufferedWrite

      protected boolean flushBufferedWrite() throws IOException
      Description copied from class: AbstractProcessor
      Flush any pending writes. Used during non-blocking writes to flush any remaining data from a previous incomplete write.
      Specified by:
      flushBufferedWrite in class AbstractProcessor
      Returns:
      true if data remains to be flushed at the end of method
      Throws:
      IOException - If an I/O error occurs while attempting to flush the data
    • dispatchNonBlockingRead

      protected void dispatchNonBlockingRead()
      Description copied from class: AbstractProcessor
      Perform any necessary processing for a non-blocking read before dispatching to the adapter.
      Overrides:
      dispatchNonBlockingRead in class AbstractProcessor
    • dispatchEndRequest

      protected AbstractEndpoint.Handler.SocketState dispatchEndRequest()
      Description copied from class: AbstractProcessor
      Perform any necessary clean-up processing if the dispatch resulted in the completion of processing for the current request.
      Specified by:
      dispatchEndRequest in class AbstractProcessor
      Returns:
      The state to return for the socket once the clean-up for the current request has completed
    • service

      Description copied from class: AbstractProcessorLight
      Service a 'standard' HTTP request. This method is called for both new requests and for requests that have partially read the HTTP request line or HTTP headers. Once the headers have been fully read this method is not called again until there is a new HTTP request to process. Note that the request type may change during processing which may result in one or more calls to AbstractProcessorLight.dispatch(SocketEvent). Requests may be pipe-lined.
      Specified by:
      service in class AbstractProcessorLight
      Parameters:
      socket - The connection to process
      Returns:
      The state the caller should put the socket in when this method returns
      Throws:
      IOException - If an I/O error occurs during the processing of the request
    • recycle

      public void recycle()
      Description copied from interface: Processor
      Recycle the processor, ready for the next request which may be on the same connection or a different connection.
      Specified by:
      recycle in interface Processor
      Overrides:
      recycle in class AbstractProcessor
    • pause

      public void pause()
      Description copied from interface: Processor
      Informs the processor that the underlying I/O layer has stopped accepting new connections. This is primarily intended to enable processors that use multiplexed connections to prevent further 'streams' being added to an existing multiplexed connection.
    • refillReadBuffer

      protected boolean refillReadBuffer(boolean block) throws IOException
      Get more request body data from the web server and store it in the internal buffer.
      Parameters:
      block - true if this is blocking IO
      Returns:
      true if there is more data, false if not.
      Throws:
      IOException - An IO error occurred
    • populateHost

      protected void populateHost()
      Called when a host header is not present in the request (e.g. HTTP/1.0). It populates the server name with appropriate information. The source is expected to vary by protocol.

      The default implementation is a NO-OP.

      This implementation populates the server name from the local name provided by the AJP message.

      Overrides:
      populateHost in class AbstractProcessor
    • populatePort

      protected void populatePort()
      Called when a host header is not present or is empty in the request (e.g. HTTP/1.0). It populates the server port with appropriate information. The source is expected to vary by protocol.

      The default implementation is a NO-OP.

      This implementation populates the server port from the local port provided by the AJP message.

      Overrides:
      populatePort in class AbstractProcessor
    • prepareResponse

      protected final void prepareResponse() throws IOException
      When committing the response, we have to validate the set of headers, as well as setup the response filters.
      Specified by:
      prepareResponse in class AbstractProcessor
      Throws:
      IOException
    • flush

      protected final void flush() throws IOException
      Callback to write data from the buffer.
      Specified by:
      flush in class AbstractProcessor
      Throws:
      IOException
    • finishResponse

      protected final void finishResponse() throws IOException
      Finish AJP response.
      Specified by:
      finishResponse in class AbstractProcessor
      Throws:
      IOException
    • ack

      protected final void ack(ContinueResponseTiming continueResponseTiming)
      Specified by:
      ack in class AbstractProcessor
    • available

      protected final int available(boolean doRead)
      Specified by:
      available in class AbstractProcessor
    • setRequestBody

      protected final void setRequestBody(ByteChunk body)
      Specified by:
      setRequestBody in class AbstractProcessor
    • setSwallowResponse

      protected final void setSwallowResponse()
      Specified by:
      setSwallowResponse in class AbstractProcessor
    • disableSwallowRequest

      protected final void disableSwallowRequest()
      Specified by:
      disableSwallowRequest in class AbstractProcessor
    • getPopulateRequestAttributesFromSocket

      protected final boolean getPopulateRequestAttributesFromSocket()
      Description copied from class: AbstractProcessor
      Processors that populate request attributes directly (e.g. AJP) should over-ride this method and return false.
      Overrides:
      getPopulateRequestAttributesFromSocket in class AbstractProcessor
      Returns:
      true if the SocketWrapper should be used to populate the request attributes, otherwise false.
    • populateRequestAttributeRemoteHost

      protected final void populateRequestAttributeRemoteHost()
      Description copied from class: AbstractProcessor
      Populate the remote host request attribute. Processors (e.g. AJP) that populate this from an alternative source should override this method.
      Overrides:
      populateRequestAttributeRemoteHost in class AbstractProcessor
    • populateSslRequestAttributes

      protected final void populateSslRequestAttributes()
      Description copied from class: AbstractProcessor
      Populate the TLS related request attributes from the SSLSupport instance associated with this processor. Protocols that populate TLS attributes from a different source (e.g. AJP) should override this method.
      Overrides:
      populateSslRequestAttributes in class AbstractProcessor
    • isRequestBodyFullyRead

      protected final boolean isRequestBodyFullyRead()
      Specified by:
      isRequestBodyFullyRead in class AbstractProcessor
    • registerReadInterest

      protected final void registerReadInterest()
      Specified by:
      registerReadInterest in class AbstractProcessor
    • isReadyForWrite

      protected final boolean isReadyForWrite()
      Specified by:
      isReadyForWrite in class AbstractProcessor
    • getLog

      protected Log getLog()
      Specified by:
      getLog in class AbstractProcessorLight