Package org.apache.coyote
Class Request
- java.lang.Object
- 
- org.apache.coyote.Request
 
- 
 public final class Request extends Object This is a low-level, efficient representation of a server request. Most fields are GC-free, expensive operations are delayed until the user code needs the information. Processing is delegated to modules, using a hook mechanism. This class is not intended for user code - it is used internally by tomcat for processing the request in the most efficient way. Users ( servlets ) can access the information using a facade, which provides the high-level view of the request. Tomcat defines a number of attributes:- "org.apache.tomcat.request" - allows access to the low-level request object in trusted applications
 - Author:
- James Duncan Davidson [duncan@eng.sun.com], James Todd [gonzo@eng.sun.com], Jason Hunter [jch@eng.sun.com], Harish Prabandham, Alex Cruikshank [alex@epitonic.com], Hans Bergsten [hans@gefionsoftware.com], Costin Manolache, Remy Maucherat
 
- 
- 
Constructor SummaryConstructors Constructor Description Request()
 - 
Method Summary
 
- 
- 
- 
Method Detail- 
getReadListenerpublic ReadListener getReadListener() 
 - 
setReadListenerpublic void setReadListener(ReadListener listener) 
 - 
isReadypublic boolean isReady() 
 - 
onDataAvailablepublic void onDataAvailable() throws IOException- Throws:
- IOException
 
 - 
sendAllDataReadEventpublic boolean sendAllDataReadEvent() 
 - 
getMimeHeaderspublic MimeHeaders getMimeHeaders() 
 - 
isTrailerFieldsReadypublic boolean isTrailerFieldsReady() 
 - 
getURLDecoderpublic UDecoder getURLDecoder() 
 - 
schemepublic MessageBytes scheme() 
 - 
methodpublic MessageBytes method() 
 - 
requestURIpublic MessageBytes requestURI() 
 - 
decodedURIpublic MessageBytes decodedURI() 
 - 
queryStringpublic MessageBytes queryString() 
 - 
protocolpublic MessageBytes protocol() 
 - 
serverNamepublic MessageBytes serverName() Get the "virtual host", derived from the Host: header associated with this request.- Returns:
- The buffer holding the server name, if any. Use isNull() to check if there is no value set.
 
 - 
getServerPortpublic int getServerPort() 
 - 
setServerPortpublic void setServerPort(int serverPort) 
 - 
remoteAddrpublic MessageBytes remoteAddr() 
 - 
peerAddrpublic MessageBytes peerAddr() 
 - 
remoteHostpublic MessageBytes remoteHost() 
 - 
localNamepublic MessageBytes localName() 
 - 
localAddrpublic MessageBytes localAddr() 
 - 
getRemotePortpublic int getRemotePort() 
 - 
setRemotePortpublic void setRemotePort(int port) 
 - 
getLocalPortpublic int getLocalPort() 
 - 
setLocalPortpublic void setLocalPort(int port) 
 - 
getCharacterEncodingpublic String getCharacterEncoding() Get the character encoding used for this request.- Returns:
- The value set via setCharset(Charset)or if no call has been made to that method try to obtain if from the content type.
 
 - 
getCharsetpublic Charset getCharset() throws UnsupportedEncodingException Get the character encoding used for this request.- Returns:
- The value set via setCharset(Charset)or if no call has been made to that method try to obtain if from the content type.
- Throws:
- UnsupportedEncodingException- If the user agent has specified an invalid character encoding
 
 - 
setCharsetpublic void setCharset(Charset charset) 
 - 
setContentLengthpublic void setContentLength(long len) 
 - 
getContentLengthpublic int getContentLength() 
 - 
getContentLengthLongpublic long getContentLengthLong() 
 - 
getContentTypepublic String getContentType() 
 - 
setContentTypepublic void setContentType(String type) 
 - 
contentTypepublic MessageBytes contentType() 
 - 
setContentTypepublic void setContentType(MessageBytes mb) 
 - 
setExpectationpublic void setExpectation(boolean expectation) 
 - 
hasExpectationpublic boolean hasExpectation() 
 - 
getResponsepublic Response getResponse() 
 - 
setResponsepublic void setResponse(Response response) 
 - 
setHookprotected void setHook(ActionHook hook) 
 - 
actionpublic void action(ActionCode actionCode, Object param) 
 - 
getCookiespublic ServerCookies getCookies() 
 - 
getParameterspublic Parameters getParameters() 
 - 
getRemoteUserpublic MessageBytes getRemoteUser() 
 - 
getRemoteUserNeedsAuthorizationpublic boolean getRemoteUserNeedsAuthorization() 
 - 
setRemoteUserNeedsAuthorizationpublic void setRemoteUserNeedsAuthorization(boolean remoteUserNeedsAuthorization) 
 - 
getAuthTypepublic MessageBytes getAuthType() 
 - 
getAvailablepublic int getAvailable() 
 - 
setAvailablepublic void setAvailable(int available) 
 - 
getSendfilepublic boolean getSendfile() 
 - 
setSendfilepublic void setSendfile(boolean sendfile) 
 - 
isFinishedpublic boolean isFinished() 
 - 
getSupportsRelativeRedirectspublic boolean getSupportsRelativeRedirects() 
 - 
getInputBufferpublic InputBuffer getInputBuffer() 
 - 
setInputBufferpublic void setInputBuffer(InputBuffer inputBuffer) 
 - 
doReadpublic int doRead(ApplicationBufferHandler handler) throws IOException Read data from the input buffer and put it into ApplicationBufferHandler. The buffer is owned by the protocol implementation - it will be reused on the next read. The Adapter must either process the data in place or copy it to a separate buffer if it needs to hold it. In most cases this is done during byte->char conversions or via InputStream. Unlike InputStream, this interface allows the app to process data in place, without copy.- Parameters:
- handler- The destination to which to copy the data
- Returns:
- The number of bytes copied
- Throws:
- IOException- If an I/O error occurs during the copy
 
 - 
setErrorExceptionpublic void setErrorException(Exception ex) Set the error Exception that occurred during the writing of the response processing.- Parameters:
- ex- The exception that occurred
 
 - 
getErrorExceptionpublic Exception getErrorException() Get the Exception that occurred during the writing of the response.- Returns:
- The exception that occurred
 
 - 
isExceptionPresentpublic boolean isExceptionPresent() 
 - 
getStartTimepublic long getStartTime() 
 - 
setStartTimepublic void setStartTime(long startTime) 
 - 
getThreadIdpublic long getThreadId() 
 - 
clearRequestThreadpublic void clearRequestThread() 
 - 
setRequestThreadpublic void setRequestThread() 
 - 
isRequestThreadpublic boolean isRequestThread() 
 - 
setNotepublic final void setNote(int pos, Object value)Used to store private data. Thread data could be used instead - but if you have the req, getting/setting a note is just an array access, may be faster than ThreadLocal for very frequent operations. Example use: Catalina CoyoteAdapter: ADAPTER_NOTES = 1 - stores the HttpServletRequest object ( req/res) To avoid conflicts, note in the range 0 - 8 are reserved for the servlet container ( catalina connector, etc ), and values in 9 - 16 for connector use. 17-31 range is not allocated or used.- Parameters:
- pos- Index to use to store the note
- value- The value to store at that index
 
 - 
getNotepublic final Object getNote(int pos) 
 - 
recyclepublic void recycle() 
 - 
updateCounterspublic void updateCounters() 
 - 
getRequestProcessorpublic RequestInfo getRequestProcessor() 
 - 
getBytesReadpublic long getBytesRead() 
 - 
isProcessingpublic boolean isProcessing() 
 
- 
 
-