- 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.Wrapper,SecureRequestCustomizer.SecureRequest,SecureRequestCustomizer.SecureRequestWithTLSData,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 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 -
Field Summary
FieldsFields inherited from interface org.eclipse.jetty.util.Attributes
NULL -
Method Summary
Modifier and TypeMethodDescriptionvoidaddFailureListener(Consumer<Throwable> onFailure) Adds a listener for asynchronous hard errors.voidaddHttpStreamWrapper(Function<HttpStream, HttpStream> wrapper) 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 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().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) Common point to generate a proper "Location" header for redirects.static RequestMethods inherited from interface org.eclipse.jetty.util.Attributes
asAttributeMap, clearAttributes, getAttribute, getAttributeNameSet, removeAttribute, setAttributeMethods inherited from interface org.eclipse.jetty.io.Content.Source
fail, fail, getLength, rewind
-
Field Details
-
CACHE_ATTRIBUTE
-
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. In addition to the invocation guarantees ofContent.Source.demand(Runnable), this implementation serializes the invocation of theRunnablewith invocations of anyResponse.write(boolean, ByteBuffer, Callback)Callbackinvocations.- 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 hard failure (seeaddFailureListener(Consumer)); orfalseto ignore that specific timeout and for another timeout to occur after another idle period.Any pending
demand(Runnable)orResponse.write(boolean, ByteBuffer, Callback)operations are not affected by this call. Applications need to be mindful of any such pending operations if attempting to make new operations.Listeners are processed in sequence, and the first that returns
truestops the processing of subsequent listeners, which are therefore not invoked.- Parameters:
onIdleTimeout- the predicate function- See Also:
-
addFailureListener
Adds a listener for asynchronous hard errors.
When a listener is called, the effects of the error will already have taken place:
- Pending
demand(Runnable)will be woken up. - Calls to
read()will return theThrowable. - Pending and new
Response.write(boolean, ByteBuffer, Callback)calls will be failed by callingCallback.failed(Throwable)on the callback passed towrite(...). - Any call to
Callback.succeeded()on the callback passed toRequest.Handler.handle(Request, Response, Callback)will effectively be a call toCallback.failed(Throwable)with the notifiedThrowable.
Listeners are processed in sequence. When all listeners are invoked then
Callback.failed(Throwable)will be called on the callback passed toRequest.Handler.handle(Request, Response, Callback).- Parameters:
onFailure- the consumer function- See Also:
- Pending
-
getTunnelSupport
TunnelSupport getTunnelSupport() -
addHttpStreamWrapper
-
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
-
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
-
extractQueryParameters
-
extractQueryParameters
-
getParameters
- Throws:
Exception
-
getParametersAsync
-
getCookies
-
toRedirectURI
Common point to 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.
-