- All Superinterfaces:
org.eclipse.jetty.util.Attributes,org.eclipse.jetty.io.Content.Source
- All Known Subinterfaces:
Request.ServeAs
- All Known Implementing Classes:
ContextRequest,ErrorHandler.ErrorRequest,GzipRequest,HeaderWrappingRequest,Request.AttributesWrapper,Request.Wrapper,SecureRequestCustomizer.SecureRequest,SecureRequestCustomizer.SecureRequestWithSslSessionData,StatisticsHandler.MinimumDataRateHandler.MinimumDataRateRequest
The representation of an HTTP request, for any protocol version (HTTP/1.1, HTTP/2, HTTP/3).
The typical idiom to read request content is the following:
public boolean handle(Request request, Response response, Callback callback)
{
// Reject requests not appropriate for this handler.
if (!request.getHttpURI().getPath().startsWith("/yourPath"))
return false;
while (true)
{
Content.Chunk chunk = request.read();
if (chunk == null)
{
// The chunk is not currently available, demand to be called back.
request.demand(() -> handle(request, response, callback));
return true;
}
if (Content.Chunk.isError(chunk))
{
Throwable failure = error.getCause();
// Handle errors.
// If the chunk is not last, then the error can be ignored and reading can be tried again.
// Otherwise, if the chunk is last, or we do not wish to ignore a non-last error, then
// mark the handling as complete, either generating a custom
// response and succeeding the callback, or failing the callback.
callback.failed(failure);
return true;
}
if (chunk instanceof Trailers trailers)
{
HttpFields fields = trailers.getTrailers();
// Handle trailers.
// Generate a response.
// Mark the handling as complete.
callback.succeeded();
return true;
}
// Normal chunk, process it.
processChunk(chunk);
// Release the content after processing.
chunk.release();
// Reached end-of-file?
if (chunk.isLast())
{
// Generate a response.
// Mark the handling as complete.
callback.succeeded();
return true;
}
}
}
-
Nested Class Summary
Nested ClassesModifier and TypeInterfaceDescriptionstatic classARequest.Wrapperthat separately provides the requestAttributes.static interfaceA minimal Authentication interface, primarily used for logging.static interfaceA handler for an HTTP request and response.static interfaceThis interface will be detected by theRequest.ServeAs.wrap(Request, HttpURI)static method to wrap the request changing its target to a given path.static classA wrapper forRequestinstances.Nested classes/interfaces inherited from interface org.eclipse.jetty.util.Attributes
org.eclipse.jetty.util.Attributes.Layer, org.eclipse.jetty.util.Attributes.Lazy, org.eclipse.jetty.util.Attributes.Mapped, org.eclipse.jetty.util.Attributes.Synthetic -
Field Summary
FieldsFields inherited from interface org.eclipse.jetty.util.Attributes
NULL -
Method Summary
Modifier and TypeMethodDescriptionstatic voidaddCompletionListener(Request request, Consumer<Throwable> listener) Adds a completion listener that is an optimized equivalent to overriding theCallback.succeeded()andCallback.failed(Throwable)methods of aHttpStream.Wrappercreated by a call toaddHttpStreamWrapper(Function).voidaddFailureListener(Consumer<Throwable> onFailure) Adds a listener for asynchronous fatal failures.voidaddHttpStreamWrapper(Function<HttpStream, HttpStream> wrapper) Add aHttpStream.Wrapperto the currentHttpStream.voidaddIdleTimeoutListener(Predicate<TimeoutException> onIdleTimeout) Adds a listener for idle timeouts.static <T> Tstatic InputStreamasInputStream(Request request) static RequestasReadOnly(Request request) Returns a copy of the request that throwsUnsupportedOperationExceptionfrom all mutative methods.booleanConsume any available content.voidstatic org.eclipse.jetty.util.FieldsextractQueryParameters(Request request) static org.eclipse.jetty.util.FieldsextractQueryParameters(Request request, Charset charset) static <T,R> R static Request.AuthenticationStategetAuthenticationState(Request request) longGet the nanoTime at which the request arrived to a connector, obtained viaSystem.nanoTime().static CharsetgetCharset(Request request) Get aCharsetfrom the requestHttpHeader.CONTENT_TYPE, if any.static longgetContentBytesRead(Request request) Get theContextassociated with thisRequest.static StringgetContextPath(Request request) Get the context path of thisRequest.static List<org.eclipse.jetty.http.HttpCookie> getCookies(Request request) org.eclipse.jetty.http.HttpFieldslongGet the nanoTime at which the request headers were parsed, obtained viaSystem.nanoTime().static StringgetHostName(InetSocketAddress inetSocketAddress) org.eclipse.jetty.http.HttpURIgetId()an ID unique within the lifetime scope of theConnectionMetaData.getId()).static StringgetLocalAddr(Request request) getLocales(Request request) static intgetLocalPort(Request request) static org.eclipse.jetty.util.FieldsgetParameters(Request request) static CompletableFuture<org.eclipse.jetty.util.Fields> getParametersAsync(Request request) static StringgetPathInContext(Request request) Returns the canonically encoded path of the URI, scoped to the current context.static StringgetRemoteAddr(Request request) static intgetRemotePort(Request request) static StringgetServerName(Request request) Get the logical name the request was sent to, which may be from the authority of the request; the configured server authority; the actual network name of the server;static intgetServerPort(Request request) Get the logical port a request was received on, which may be from the authority of the request; the configured server authority; the default port for the scheme; or the actual network port.getSession(boolean create) Get aSessionassociated with the request.static longgetTimeStamp(Request request) Get the millisecond timestamp at which the request was created, obtained withSystem.currentTimeMillis().org.eclipse.jetty.http.HttpFieldsbooleanisSecure()static org.eclipse.jetty.http.HttpURInewHttpURIFrom(Request request, String newEncodedPathInContext) Creates a newHttpURIfrom the given Request's HttpURI and the given path in context.default voidpush(org.eclipse.jetty.http.MetaData.Request resource) Pushes the givenresourceto the client.org.eclipse.jetty.io.Content.Chunkread()static RequestReturn a request with itsHttpURIchanged to the supplied target.static voidsetAuthenticationState(Request request, Request.AuthenticationState state) static StringtoRedirectURI(Request request, String location) Deprecated.static RequestMethods inherited from interface org.eclipse.jetty.util.Attributes
asAttributeMap, clearAttributes, equals, getAttribute, getAttributeNameSet, hashCode, removeAttribute, setAttributeMethods inherited from interface org.eclipse.jetty.io.Content.Source
fail, fail, getLength, rewind
-
Field Details
-
LOG
static final org.slf4j.Logger LOG -
COOKIE_ATTRIBUTE
-
DEFAULT_LOCALES
-
-
Method Details
-
getId
String getId()an ID unique within the lifetime scope of theConnectionMetaData.getId()). This may be a protocol ID (e.g. HTTP/2 stream ID) or it may be unrelated to the protocol.- See Also:
-
getComponents
Components getComponents()- Returns:
- the
Componentsto be used with thisRequest.
-
getConnectionMetaData
ConnectionMetaData getConnectionMetaData()- Returns:
- the
ConnectionMetaDataassociated to thisRequest
-
getMethod
String getMethod()- Returns:
- the HTTP method of this
Request
-
getHttpURI
org.eclipse.jetty.http.HttpURI getHttpURI()- Returns:
- the HTTP URI of this
Request - See Also:
-
getContext
Context getContext()Get theContextassociated with thisRequest.Note that a
Requestshould always have an associatedContextsince if theRequestis not being handled by aContextHandlerthen theContextfromServer.getContext()will be used.- Returns:
- the
Contextassociated with thisRequest. Nevernull. - See Also:
-
getContextPath
Get the context path of thisRequest. This is equivalent torequest.getContext().getContextPath().- Parameters:
request- The request to get the context path from.- Returns:
- The encoded context path of the
Contextornull. - See Also:
-
getPathInContext
Returns the canonically encoded path of the URI, scoped to the current context.
For example, when the request has a
ContextwithcontextPath=/ctxand the request'sHttpURIcanonical path iscanonicalPath=/ctx/foo, thenpathInContext=/foo.- Returns:
- The part of the canonically encoded path of the URI after any context path prefix has been removed.
- See Also:
-
getHeaders
org.eclipse.jetty.http.HttpFields getHeaders()- Returns:
- the HTTP headers of this
Request
-
demand
- Specified by:
demandin interfaceorg.eclipse.jetty.io.Content.Source- Parameters:
demandCallback- the demand callback to invoke when there is a content chunk available.- See Also:
-
getTrailers
org.eclipse.jetty.http.HttpFields getTrailers()- Returns:
- the HTTP trailers of this
Request, ornullif they are not present
-
getTimeStamp
Get the millisecond timestamp at which the request was created, obtained with
System.currentTimeMillis(). This method should be used for wall clock time, rather thangetHeadersNanoTime(), which is appropriate for measuring latencies.- Returns:
- The timestamp that the request was received/created in milliseconds
-
getBeginNanoTime
long getBeginNanoTime()Get the nanoTime at which the request arrived to a connector, obtained via
System.nanoTime(). This method can be used when measuring latencies.- Returns:
- The nanoTime at which the request was received/created in nanoseconds
-
getHeadersNanoTime
long getHeadersNanoTime()Get the nanoTime at which the request headers were parsed, obtained via
System.nanoTime(). This method can be used when measuring latencies.- Returns:
- The nanoTime at which the request was ready in nanoseconds
-
isSecure
boolean isSecure() -
read
org.eclipse.jetty.io.Content.Chunk read()In addition, the returned
Content.Chunkmay be aTrailersinstance, in case of request content trailers.- Specified by:
readin interfaceorg.eclipse.jetty.io.Content.Source
-
consumeAvailable
boolean consumeAvailable()Consume any available content. This bypasses any request wrappers to process the content inread()and reads directly from theHttpStream. This reads until there is no content currently available, or it reaches EOF. TheHttpConfiguration.setMaxUnconsumedRequestContentReads(int)configuration can be used to configure how many reads will be attempted by this method.- Returns:
- true if the content was fully consumed.
-
push
default void push(org.eclipse.jetty.http.MetaData.Request resource) Pushes the given
resourceto the client.- Parameters:
resource- the resource to push- Throws:
UnsupportedOperationException- if the push functionality is not supported- See Also:
-
addIdleTimeoutListener
Adds a listener for idle timeouts.
The listener is a predicate function that should return
trueto indicate that the idle timeout should be handled by the container as a fatal failure (seeaddFailureListener(Consumer)); orfalseto ignore that specific timeout and for another timeout to occur after another idle period.Idle timeout listeners are only invoked if there are no pending
demand(Runnable)orResponse.write(boolean, ByteBuffer, Callback)operations.Listeners are processed in the same order they are added, and the first that returns
truestops the processing of subsequent listeners, which are therefore not invoked.- Parameters:
onIdleTimeout- the idle timeout listener as a predicate function- See Also:
-
addFailureListener
Adds a listener for asynchronous fatal failures.
When a listener is called, the effects of the failure have already taken place:
- Pending
demand(Runnable)have been woken up. - Calls to
read()will return theThrowablefailure. - Pending and new
Response.write(boolean, ByteBuffer, Callback)calls will be failed by callingCallback.failed(Throwable)on the callback passed toResponse.write(boolean, ByteBuffer, Callback).
Listeners are processed in the same order they are added.
- Parameters:
onFailure- the failure listener as a consumer function- See Also:
- Pending
-
getTunnelSupport
TunnelSupport getTunnelSupport() -
addHttpStreamWrapper
Add aHttpStream.Wrapperto the currentHttpStream.- Parameters:
wrapper- A function that wraps the passed stream.- See Also:
-
addCompletionListener
Adds a completion listener that is an optimized equivalent to overriding the
Callback.succeeded()andCallback.failed(Throwable)methods of aHttpStream.Wrappercreated by a call toaddHttpStreamWrapper(Function).Because adding completion listeners relies on
HttpStreamwrapping, the completion listeners are invoked in reverse order they are added.In the case of a failure, the
Throwablecause is passed to the listener, but unlikeaddFailureListener(Consumer)listeners, which are called when the failure occurs, completion listeners are called only once theHttpStreamis completed at the very end of processing. -
getSession
Get a
Sessionassociated with the request. Sessions may not be supported by a given configuration, in which casenullwill be returned.- Parameters:
create- True if the session should be created for the request.- Returns:
- The session associated with the request or
null.
-
asReadOnly
Returns a copy of the request that throwsUnsupportedOperationExceptionfrom all mutative methods.- Returns:
- a copy of the request
-
getHostName
-
getLocalAddr
-
getLocalPort
-
getRemoteAddr
-
getRemotePort
-
getServerName
Get the logical name the request was sent to, which may be from the authority of the request; the configured server authority; the actual network name of the server;- Parameters:
request- The request to get the server name of- Returns:
- The logical server name or null if it cannot be determined.
-
getServerPort
Get the logical port a request was received on, which may be from the authority of the request; the configured server authority; the default port for the scheme; or the actual network port.- Parameters:
request- The request to get the port of- Returns:
- The port for the request if it can be determined, otherwise -1
-
getLocales
-
asInputStream
-
getCharset
static Charset getCharset(Request request) throws IllegalCharsetNameException, UnsupportedCharsetException Get aCharsetfrom the requestHttpHeader.CONTENT_TYPE, if any.- Parameters:
request- The request.- Returns:
- A
Charsetor null - Throws:
IllegalCharsetNameException- If the charset name is illegalUnsupportedCharsetException- If no support for the charset is available
-
extractQueryParameters
-
extractQueryParameters
-
getParameters
- Throws:
Exception
-
getParametersAsync
-
getCookies
-
toRedirectURI
Deprecated.Generate a proper "Location" header for redirects.- Parameters:
request- the request the redirect should be based on (needed when relative locations are provided, so that server name, scheme, port can be built out properly)location- the location URL to redirect to (can be a relative path)- Returns:
- the full redirect "Location" URL (including scheme, host, port, path, etc...)
-
serveAs
Return a request with itsHttpURIchanged to the supplied target. If the passed request or any of the requests that it wraps implementsRequest.ServeAsthenRequest.ServeAs.wrap(Request, HttpURI)will be used to do the wrap, otherwise a simpleRequest.Wrappermay be returned.- Parameters:
request- the original request.uri- the new URI to target.- Returns:
- the possibly wrapped request to target the new URI.
-
as
-
get
-
unWrap
-
getContentBytesRead
-
newHttpURIFrom
static org.eclipse.jetty.http.HttpURI newHttpURIFrom(Request request, String newEncodedPathInContext) Creates a new
HttpURIfrom the given Request's HttpURI and the given path in context.For example, for
contextPath=/ctx,request.httpURI=http://host/ctx/path?a=b, andnewPathInContext=/newPath, the returned HttpURI ishttp://host/ctx/newPath?a=b.- Parameters:
request- The request to base the new HttpURI on.newEncodedPathInContext- The new path in context for the new HttpURI- Returns:
- A new immutable HttpURI with the path in context replaced, but query string and path parameters retained.
-
getAuthenticationState
- Parameters:
request- The request to enquire.- Returns:
- the minimal
Request.AuthenticationStateof the request, or null if no authentication in process.
-
setAuthenticationState
- Parameters:
request- The request to enquire.state- theRequest.AuthenticationStateof the request, or null if no authentication in process.
-
Response.toRedirectURI(Request, String)