Interface Request
- 
- All Known Implementing Classes:
- HttpRequest,- WebSocketUpgradeRequest
 
 public interface RequestRequestrepresents an HTTP request, and offers a fluent interface to customize various attributes such as the path, the headers, the content, etc.You can create Requestobjects viaHttpClient.newRequest(String)and you can send them using eithersend()for a blocking semantic, orsend(Response.CompleteListener)for an asynchronous semantic.- See Also:
- Response
 
- 
- 
Nested Class SummaryNested Classes Modifier and Type Interface Description static interfaceRequest.BeginListenerListener for the request begin event.static interfaceRequest.CommitListenerListener for the request committed event.static interfaceRequest.ContentListenerListener for the request content event.static interfaceRequest.FailureListenerListener for the request failed event.static interfaceRequest.HeadersListenerListener for the request headers event.static interfaceRequest.ListenerListener for all request events.static interfaceRequest.QueuedListenerListener for the request queued event.static interfaceRequest.RequestListenerCommon, empty, super-interface for request listeners.static interfaceRequest.SuccessListenerListener for the request succeeded event.
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description booleanabort(java.lang.Throwable cause)Attempts to abort the send of this request.Requestaccept(java.lang.String... accepts)Requestagent(java.lang.String agent)Requestattribute(java.lang.String name, java.lang.Object value)Requestcontent(ContentProvider content)Requestcontent(ContentProvider content, java.lang.String contentType)Requestcookie(java.net.HttpCookie cookie)Requestfile(java.nio.file.Path file)Shortcut method to specify a file as a content for this request, with the default content type of "application/octect-stream".Requestfile(java.nio.file.Path file, java.lang.String contentType)Shortcut method to specify a file as a content for this request, with the given content type.RequestfollowRedirects(boolean follow)java.lang.ThrowablegetAbortCause()java.lang.StringgetAgent()java.util.Map<java.lang.String,java.lang.Object>getAttributes()ContentProvidergetContent()java.util.List<java.net.HttpCookie>getCookies()HttpFieldsgetHeaders()java.lang.StringgetHost()longgetIdleTimeout()java.lang.StringgetMethod()FieldsgetParams()java.lang.StringgetPath()intgetPort()java.lang.StringgetQuery()<T extends Request.RequestListener>
 java.util.List<T>getRequestListeners(java.lang.Class<T> listenerClass)java.lang.StringgetScheme()java.lang.ObjectgetTag()longgetTimeout()java.net.URIgetURI()HttpVersiongetVersion()Requestheader(java.lang.String name, java.lang.String value)Requestheader(HttpHeader header, java.lang.String value)Adds the givenvalueto the specifiedheader.default Requesthost(java.lang.String host)RequestidleTimeout(long timeout, java.util.concurrent.TimeUnit unit)booleanisFollowRedirects()Requestlistener(Request.Listener listener)Requestmethod(java.lang.String method)Requestmethod(HttpMethod method)RequestonComplete(Response.CompleteListener listener)RequestonRequestBegin(Request.BeginListener listener)RequestonRequestCommit(Request.CommitListener listener)RequestonRequestContent(Request.ContentListener listener)RequestonRequestFailure(Request.FailureListener listener)RequestonRequestHeaders(Request.HeadersListener listener)RequestonRequestQueued(Request.QueuedListener listener)RequestonRequestSuccess(Request.SuccessListener listener)RequestonResponseBegin(Response.BeginListener listener)RequestonResponseContent(Response.ContentListener listener)RequestonResponseContentAsync(Response.AsyncContentListener listener)RequestonResponseContentDemanded(Response.DemandedContentListener listener)RequestonResponseFailure(Response.FailureListener listener)RequestonResponseHeader(Response.HeaderListener listener)RequestonResponseHeaders(Response.HeadersListener listener)RequestonResponseSuccess(Response.SuccessListener listener)Requestparam(java.lang.String name, java.lang.String value)Adds a URI query parameter with the given name and value.Requestpath(java.lang.String path)Specifies the URI path - and possibly the query - of this request.default Requestport(int port)Requestscheme(java.lang.String scheme)ContentResponsesend()Sends this request and returns the response.voidsend(Response.CompleteListener listener)Sends this request and asynchronously notifies the given listener for response events.Requesttag(java.lang.Object tag)Tags this request with the given metadata tag.Requesttimeout(long timeout, java.util.concurrent.TimeUnit unit)Requestversion(HttpVersion version)
 
- 
- 
- 
Method Detail- 
getSchemejava.lang.String getScheme() - Returns:
- the URI scheme of this request, such as "http" or "https"
 
 - 
schemeRequest scheme(java.lang.String scheme) - Parameters:
- scheme- the URI scheme of this request, such as "http" or "https"
- Returns:
- this request object
 
 - 
getHostjava.lang.String getHost() - Returns:
- the URI host of this request, such as "127.0.0.1" or "google.com"
 
 - 
hostdefault Request host(java.lang.String host) - Parameters:
- host- the URI host of this request, such as "127.0.0.1" or "google.com"
- Returns:
- this request object
 
 - 
getPortint getPort() - Returns:
- the URI port of this request such as 80 or 443
 
 - 
portdefault Request port(int port) - Parameters:
- port- the URI port of this request such as 80 or 443
- Returns:
- this request object
 
 - 
getMethodjava.lang.String getMethod() - Returns:
- the method of this request, such as GET or POST, as a String
 
 - 
methodRequest method(HttpMethod method) - Parameters:
- method- the method of this request, such as GET or POST
- Returns:
- this request object
 
 - 
methodRequest method(java.lang.String method) - Parameters:
- method- the method of this request, such as GET or POST
- Returns:
- this request object
 
 - 
getPathjava.lang.String getPath() - Returns:
- the URI path of this request, such as "/" or "/path" - without the query
- See Also:
- getQuery()
 
 - 
pathRequest path(java.lang.String path) Specifies the URI path - and possibly the query - of this request. If the query part is specified, parameter values must be properlyUTF-8 URL encoded. For example, if the value for parameter "currency" is the euro symbol € then the query string for this parameter must be "currency=%E2%82%AC". For transparent encoding of parameter values, useparam(String, String).- Parameters:
- path- the URI path of this request, such as "/" or "/path?param=1"
- Returns:
- this request object
 
 - 
getQueryjava.lang.String getQuery() - Returns:
- the URI query string of this request such as "param=1"
- See Also:
- getPath(),- getParams()
 
 - 
getURIjava.net.URI getURI() - Returns:
- the full URI of this request such as "http://host:port/path?param=1"
 
 - 
getVersionHttpVersion getVersion() - Returns:
- the HTTP version of this request, such as "HTTP/1.1"
 
 - 
versionRequest version(HttpVersion version) - Parameters:
- version- the HTTP version of this request, such as "HTTP/1.1"
- Returns:
- this request object
 
 - 
getParamsFields getParams() - Returns:
- the URI query parameters of this request
 
 - 
paramRequest param(java.lang.String name, java.lang.String value) Adds a URI query parameter with the given name and value. The value isUTF-8 URL encoded.- Parameters:
- name- the name of the query parameter
- value- the value of the query parameter
- Returns:
- this request object
 
 - 
getHeadersHttpFields getHeaders() - Returns:
- the headers of this request
 
 - 
headerRequest header(java.lang.String name, java.lang.String value) - Parameters:
- name- the name of the header
- value- the value of the header
- Returns:
- this request object
- See Also:
- header(HttpHeader, String)
 
 - 
headerRequest header(HttpHeader header, java.lang.String value) Adds the given valueto the specifiedheader.Multiple calls with the same parameters will add multiple values; use the value nullto remove the header completely.- Parameters:
- header- the header name
- value- the value of the header
- Returns:
- this request object
 
 - 
getCookiesjava.util.List<java.net.HttpCookie> getCookies() - Returns:
- the cookies associated with this request
 
 - 
cookieRequest cookie(java.net.HttpCookie cookie) - Parameters:
- cookie- a cookie for this request
- Returns:
- this request object
 
 - 
tagRequest tag(java.lang.Object tag) Tags this request with the given metadata tag. Each different tag will create a different destination, even if the destination origin is the same. This is particularly useful in proxies, where requests for the same origin but from different clients may be tagged with client's metadata (e.g. the client remote address). The tag metadata class must correctly implement Object.hashCode()andObject.equals(Object)so that it can be used, along with the origin, to identify a destination.- Parameters:
- tag- the metadata to tag the request with
- Returns:
- this request object
 
 - 
getTagjava.lang.Object getTag() - Returns:
- the metadata this request has been tagged with
 
 - 
attributeRequest attribute(java.lang.String name, java.lang.Object value) - Parameters:
- name- the name of the attribute
- value- the value of the attribute
- Returns:
- this request object
 
 - 
getAttributesjava.util.Map<java.lang.String,java.lang.Object> getAttributes() - Returns:
- the attributes of this request
 
 - 
getContentContentProvider getContent() - Returns:
- the content provider of this request
 
 - 
contentRequest content(ContentProvider content) - Parameters:
- content- the content provider of this request
- Returns:
- this request object
 
 - 
contentRequest content(ContentProvider content, java.lang.String contentType) - Parameters:
- content- the content provider of this request
- contentType- the content type
- Returns:
- this request object
 
 - 
fileRequest file(java.nio.file.Path file) throws java.io.IOException Shortcut method to specify a file as a content for this request, with the default content type of "application/octect-stream".- Parameters:
- file- the file to upload
- Returns:
- this request object
- Throws:
- java.io.IOException- if the file does not exist or cannot be read
 
 - 
fileRequest file(java.nio.file.Path file, java.lang.String contentType) throws java.io.IOException Shortcut method to specify a file as a content for this request, with the given content type.- Parameters:
- file- the file to upload
- contentType- the content type of the file
- Returns:
- this request object
- Throws:
- java.io.IOException- if the file does not exist or cannot be read
 
 - 
getAgentjava.lang.String getAgent() - Returns:
- the user agent for this request
 
 - 
agentRequest agent(java.lang.String agent) - Parameters:
- agent- the user agent for this request (corresponds to the- User-Agentheader)
- Returns:
- this request object
 
 - 
acceptRequest accept(java.lang.String... accepts) - Parameters:
- accepts- the media types that are acceptable in the response, such as "text/plain;q=0.5" or "text/html" (corresponds to the- Acceptheader)
- Returns:
- this request object
 
 - 
getIdleTimeoutlong getIdleTimeout() - Returns:
- the idle timeout for this request, in milliseconds
 
 - 
idleTimeoutRequest idleTimeout(long timeout, java.util.concurrent.TimeUnit unit) - Parameters:
- timeout- the idle timeout for this request
- unit- the idle timeout unit
- Returns:
- this request object
 
 - 
getTimeoutlong getTimeout() - Returns:
- the total timeout for this request, in milliseconds; zero or negative if the timeout is disabled
 
 - 
timeoutRequest timeout(long timeout, java.util.concurrent.TimeUnit unit) - Parameters:
- timeout- the total timeout for the request/response conversation; use zero or a negative value to disable the timeout
- unit- the timeout unit
- Returns:
- this request object
 
 - 
isFollowRedirectsboolean isFollowRedirects() - Returns:
- whether this request follows redirects
 
 - 
followRedirectsRequest followRedirects(boolean follow) - Parameters:
- follow- whether this request follows redirects
- Returns:
- this request object
 
 - 
getRequestListeners<T extends Request.RequestListener> java.util.List<T> getRequestListeners(java.lang.Class<T> listenerClass) - Type Parameters:
- T- the type of listener class
- Parameters:
- listenerClass- the class of the listener, or null for all listeners classes
- Returns:
- the listeners for request events of the given class
 
 - 
listenerRequest listener(Request.Listener listener) - Parameters:
- listener- a listener for request events
- Returns:
- this request object
 
 - 
onRequestQueuedRequest onRequestQueued(Request.QueuedListener listener) - Parameters:
- listener- a listener for request queued event
- Returns:
- this request object
 
 - 
onRequestBeginRequest onRequestBegin(Request.BeginListener listener) - Parameters:
- listener- a listener for request begin event
- Returns:
- this request object
 
 - 
onRequestHeadersRequest onRequestHeaders(Request.HeadersListener listener) - Parameters:
- listener- a listener for request headers event
- Returns:
- this request object
 
 - 
onRequestCommitRequest onRequestCommit(Request.CommitListener listener) - Parameters:
- listener- a listener for request commit event
- Returns:
- this request object
 
 - 
onRequestContentRequest onRequestContent(Request.ContentListener listener) - Parameters:
- listener- a listener for request content events
- Returns:
- this request object
 
 - 
onRequestSuccessRequest onRequestSuccess(Request.SuccessListener listener) - Parameters:
- listener- a listener for request success event
- Returns:
- this request object
 
 - 
onRequestFailureRequest onRequestFailure(Request.FailureListener listener) - Parameters:
- listener- a listener for request failure event
- Returns:
- this request object
 
 - 
onResponseBeginRequest onResponseBegin(Response.BeginListener listener) - Parameters:
- listener- a listener for response begin event
- Returns:
- this request object
 
 - 
onResponseHeaderRequest onResponseHeader(Response.HeaderListener listener) - Parameters:
- listener- a listener for response header event
- Returns:
- this request object
 
 - 
onResponseHeadersRequest onResponseHeaders(Response.HeadersListener listener) - Parameters:
- listener- a listener for response headers event
- Returns:
- this request object
 
 - 
onResponseContentRequest onResponseContent(Response.ContentListener listener) - Parameters:
- listener- a consuming listener for response content events
- Returns:
- this request object
 
 - 
onResponseContentAsyncRequest onResponseContentAsync(Response.AsyncContentListener listener) - Parameters:
- listener- an asynchronous listener for response content events
- Returns:
- this request object
 
 - 
onResponseContentDemandedRequest onResponseContentDemanded(Response.DemandedContentListener listener) - Parameters:
- listener- an asynchronous listener for response content events
- Returns:
- this request object
 
 - 
onResponseSuccessRequest onResponseSuccess(Response.SuccessListener listener) - Parameters:
- listener- a listener for response success event
- Returns:
- this request object
 
 - 
onResponseFailureRequest onResponseFailure(Response.FailureListener listener) - Parameters:
- listener- a listener for response failure event
- Returns:
- this request object
 
 - 
onCompleteRequest onComplete(Response.CompleteListener listener) - Parameters:
- listener- a listener for complete event
- Returns:
- this request object
 
 - 
sendContentResponse send() throws java.lang.InterruptedException, java.util.concurrent.TimeoutException, java.util.concurrent.ExecutionException Sends this request and returns the response.This method should be used when a simple blocking semantic is needed, and when it is known that the response content can be buffered without exceeding memory constraints. For example, this method is not appropriate to download big files from a server; consider using send(Response.CompleteListener)instead, passing your ownResponse.Listeneror a utility listener such asInputStreamResponseListener.The method returns when the complete eventis fired.- Returns:
- a ContentResponsefor this request
- Throws:
- java.lang.InterruptedException- if send thread is interrupted
- java.util.concurrent.TimeoutException- if send times out
- java.util.concurrent.ExecutionException- if execution fails
- See Also:
- Response.CompleteListener.onComplete(Result)
 
 - 
sendvoid send(Response.CompleteListener listener) Sends this request and asynchronously notifies the given listener for response events. This method should be used when the application needs to be notified of the various response events as they happen, or when the application needs to efficiently manage the response content. The listener passed to this method may implement not only Response.CompleteListenerbut also other response listener interfaces, and all the events implemented will be notified. This allows application code to write a single listener class to handle all relevant events.- Parameters:
- listener- the listener that receives response events
 
 - 
abortboolean abort(java.lang.Throwable cause) Attempts to abort the send of this request.- Parameters:
- cause- the abort cause, must not be null
- Returns:
- whether the abort succeeded
 
 - 
getAbortCausejava.lang.Throwable getAbortCause() - Returns:
- the abort cause passed to abort(Throwable), or null if this request has not been aborted
 
 
- 
 
-