Interface HttpRequest<T>
- 
- Type Parameters:
- T- the type of response body
 
 public interface HttpRequest<T>A client-side HTTP request.Instances are created by an WebClientinstance, via one of the methods corresponding to the specific HTTP methods such asWebClient.get(java.lang.String), etc...The request shall be configured prior sending, the request is immutable and when a mutator method is called, a new request is returned allowing to expose the request in a public API and apply further customization. After the request has been configured, the methods can be called. ThesendXXXmethods perform the actual request, they can be called multiple times to perform the same HTTP request at different points in time.The handler is called back with - an HttpResponseinstance when the HTTP response has been received
- a failure when the HTTP request failed (like a connection error) or when the HTTP response could not be obtained (like connection or unmarshalling errors)
 Most of the time, this client will buffer the HTTP response fully unless a specific BodyCodecis used such asBodyCodec#create(Handler).- Author:
- Julien Viet
 
- 
- 
Method SummaryAll Methods Instance Methods Abstract Methods Default Methods Modifier and Type Method Description HttpRequest<T>addQueryParam(String paramName, String paramValue)Add a query parameter to the request.<U> HttpRequest<U>as(BodyCodec<U> responseCodec)Configure the request to decode the response with theresponseCodec.HttpRequest<T>authentication(Credentials credentials)Configure the request to perform HTTP Authentication.default HttpRequest<T>basicAuthentication(Buffer id, Buffer password)Configure the request to perform basic access authentication.default HttpRequest<T>basicAuthentication(String id, String password)Configure the request to perform basic access authentication.default HttpRequest<T>bearerTokenAuthentication(String bearerToken)Configure the request to perform bearer token authentication.BodyCodec<T>bodyCodec()longconnectTimeout()HttpRequest<T>connectTimeout(long timeout)Sets the amount of time after which, if the request is not obtained from the client within the timeout period, the response is failed with aTimeoutException.HttpRequest<T>copy()Copy this requestbooleanfollowRedirects()HttpRequest<T>followRedirects(boolean value)Set whether to follow request redirectionsMultiMapheaders()Stringhost()HttpRequest<T>host(String value)Configure the request to use a new hostvalue.longidleTimeout()HttpRequest<T>idleTimeout(long timeout)Sets the amount of time after which, if the request does not return any data within the timeout period, the request/response is closed and the related futures are failed with aTimeoutException.HttpMethodmethod()HttpRequest<T>method(HttpMethod value)Configure the request to use a new methodvalue.booleanmultipartMixed()HttpRequest<T>multipartMixed(boolean allow)Allow or disallow multipart mixed encoding when sendingMultipartFormhaving files sharing the same file name.intport()HttpRequest<T>port(int value)Configure the request to use a new portvalue.ProxyOptionsproxy()HttpRequest<T>proxy(ProxyOptions proxyOptions)Configure the request to set a proxy for this request.HttpRequest<T>putHeader(String name, Iterable<String> value)Configure the request to set a new HTTP header with multiple values.HttpRequest<T>putHeader(String name, String value)Configure the request to set a new HTTP header.HttpRequest<T>putHeaders(MultiMap headers)Configure the request to add multiple HTTP headers .MultiMapqueryParams()Return the current query parameters.StringroutingKey()Return the routing key, the routing key can be used by a Vert.x client side sticky load balancer to pin the request to a remote HTTP server.HttpRequest<T>routingKey(String key)Set the routing key, the routing key can be used by a Vert.x client side sticky load balancer to pin the request to a remote HTTP server.Future<HttpResponse<T>>send()Send a request, thehandlerwill receive the response as anHttpResponse.Future<HttpResponse<T>>sendBuffer(Buffer body)Likesend()but with an HTTP requestbodybuffer.Future<HttpResponse<T>>sendForm(MultiMap body)Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set toapplication/x-www-form-urlencoded.Future<HttpResponse<T>>sendForm(MultiMap body, String charset)Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set toapplication/x-www-form-urlencoded.Future<HttpResponse<T>>sendJson(Object body)Likesend()but with an HTTP requestbodyobject encoded as json and the content type set toapplication/json.Future<HttpResponse<T>>sendJsonObject(JsonObject body)Likesend()but with an HTTP requestbodyobject encoded as json and the content type set toapplication/json.Future<HttpResponse<T>>sendMultipartForm(MultipartForm body)Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set tomultipart/form-data.Future<HttpResponse<T>>sendStream(ReadStream<Buffer> body)Likesend()but with an HTTP requestbodystream.HttpRequest<T>setQueryParam(String paramName, String paramValue)Set a query parameter to the request.HttpRequest<T>setTemplateParam(String paramName, String paramValue)Set a request URI template string parameter to the request, expanded when the request URI is aUriTemplate.HttpRequest<T>setTemplateParam(String paramName, List<String> paramValue)Set a request URI template list parameter to the request, expanded when the request URI is aUriTemplate.HttpRequest<T>setTemplateParam(String paramName, Map<String,String> paramValue)Set a request URI template map parameter to the request, expanded when the request URI is aUriTemplate.Booleanssl()HttpRequest<T>ssl(Boolean value)Configure the request whether to use SSL.VariablestemplateParams()Return the current request URI template parameters.longtimeout()HttpRequest<T>timeout(long value)Configures the amount of time in milliseconds after which if the request does not return any data within the timeout period anTimeoutExceptionfails the request.StringtraceOperation()HttpRequest<T>traceOperation(String traceOperation)Trace operation name override.Stringuri()HttpRequest<T>uri(String value)Configure the request to use a new request URIvalue.StringvirtualHost()HttpRequest<T>virtualHost(String value)Configure the request to use a virtual hostvalue.
 
- 
- 
- 
Method Detail- 
methodHttpRequest<T> method(HttpMethod value) Configure the request to use a new methodvalue.- Returns:
- a reference to this, so the API can be used fluently
 
 - 
methodHttpMethod method() - Returns:
- the request method
 
 - 
portHttpRequest<T> port(int value) Configure the request to use a new portvalue.This overrides the port set by absolute URI requests - Returns:
- a reference to this, so the API can be used fluently
 
 - 
portint port() - Returns:
- the request port or 0when none is set for absolute URI templates
 
 - 
as<U> HttpRequest<U> as(BodyCodec<U> responseCodec) Configure the request to decode the response with theresponseCodec.- Parameters:
- responseCodec- the response codec
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
hostHttpRequest<T> host(String value) Configure the request to use a new hostvalue.This overrides the host set by absolute URI requests - Returns:
- a reference to this, so the API can be used fluently
 
 - 
hostString host() - Returns:
- the request host or nullwhen none is set for absolute URI templates
 
 - 
virtualHostHttpRequest<T> virtualHost(String value) Configure the request to use a virtual hostvalue. Usually the header host (:authority pseudo header for HTTP/2) is set from the request host value since this host value resolves to the server IP address. Sometimes you need to set a host header for an address that does not resolve to the server IP address. The virtual host value overrides the value of the actual host header (:authority pseudo header for HTTP/2). The virtual host is also be used for SNI.- Returns:
- a reference to this, so the API can be used fluently
 
 - 
virtualHostString virtualHost() - Returns:
- the request virtual host if any or null
 
 - 
uriHttpRequest<T> uri(String value) Configure the request to use a new request URIvalue.This overrides the port set by absolute URI requests When the uri has query parameters, they are set in the queryParams(), overwriting any parameters previously set- Returns:
- a reference to this, so the API can be used fluently
 
 - 
uriString uri() - Returns:
- the request uri or nullwhen none is set for absolute URI templates
 
 - 
putHeadersHttpRequest<T> putHeaders(MultiMap headers) Configure the request to add multiple HTTP headers .- Parameters:
- headers- The HTTP headers
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
putHeaderHttpRequest<T> putHeader(String name, String value) Configure the request to set a new HTTP header.- Parameters:
- name- the header name
- value- the header value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
putHeaderHttpRequest<T> putHeader(String name, Iterable<String> value) Configure the request to set a new HTTP header with multiple values.- Parameters:
- name- the header name
- value- the header value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
headersMultiMap headers() - Returns:
- The HTTP headers
 
 - 
authenticationHttpRequest<T> authentication(Credentials credentials) Configure the request to perform HTTP Authentication.Performs a generic authentication using the credentials provided by the user. For the sake of validation safety it is recommended that Credentials.applyHttpChallenge(String)is called to ensure that the credentials are applicable to the HTTP Challenged received on a previous request that returned a 401 response code.- Parameters:
- credentials- the credentials to use.
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
basicAuthenticationdefault HttpRequest<T> basicAuthentication(String id, String password) Configure the request to perform basic access authentication.In basic HTTP authentication, a request contains a header field of the form 'Authorization: Basic <credentials>', where credentials is the base64 encoding of id and password joined by a colon. In practical terms the arguments are converted to aUsernamePasswordCredentialsobject.- Parameters:
- id- the id
- password- the password
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
basicAuthenticationdefault HttpRequest<T> basicAuthentication(Buffer id, Buffer password) Configure the request to perform basic access authentication.In basic HTTP authentication, a request contains a header field of the form 'Authorization: Basic <credentials>', where credentials is the base64 encoding of id and password joined by a colon. In practical terms the arguments are converted to aUsernamePasswordCredentialsobject.- Parameters:
- id- the id
- password- the password
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
bearerTokenAuthenticationdefault HttpRequest<T> bearerTokenAuthentication(String bearerToken) Configure the request to perform bearer token authentication.In OAuth 2.0, a request contains a header field of the form 'Authorization: Bearer <bearerToken>', where bearerToken is the bearer token issued by an authorization server to access protected resources. In practical terms the arguments are converted to aTokenCredentialsobject.- Parameters:
- bearerToken- the bearer token
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
sslHttpRequest<T> ssl(Boolean value) Configure the request whether to use SSL.This overrides the SSL value set by absolute URI requests - Returns:
- a reference to this, so the API can be used fluently
 
 - 
sslBoolean ssl() - Returns:
- whether the request uses SSL or nullwhen none is set for absolute URI templates
 
 - 
timeoutHttpRequest<T> timeout(long value) Configures the amount of time in milliseconds after which if the request does not return any data within the timeout period anTimeoutExceptionfails the request.Setting zero or a negative valuedisables the timeout.- Parameters:
- value- The quantity of time in milliseconds.
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
timeoutlong timeout() - Returns:
- the current timeout in milliseconds
 
 - 
idleTimeoutHttpRequest<T> idleTimeout(long timeout) Sets the amount of time after which, if the request does not return any data within the timeout period, the request/response is closed and the related futures are failed with aTimeoutException. The timeout starts after a connection is obtained from the client.- Parameters:
- timeout- the amount of time in milliseconds.
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
idleTimeoutlong idleTimeout() - Returns:
- the idle timeout
 
 - 
connectTimeoutHttpRequest<T> connectTimeout(long timeout) Sets the amount of time after which, if the request is not obtained from the client within the timeout period, the response is failed with aTimeoutException. Note this is not related to the TCPHttpClientOptions.setConnectTimeout(int)option, when a request is made against a pooled HTTP client, the timeout applies to the duration to obtain a connection from the pool to serve the request, the timeout might fire because the server does not respond in time or the pool is too busy to serve a request.- Parameters:
- timeout- the amount of time in milliseconds.
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
connectTimeoutlong connectTimeout() - Returns:
- the connect timeout
 
 - 
addQueryParamHttpRequest<T> addQueryParam(String paramName, String paramValue) Add a query parameter to the request.- Parameters:
- paramName- the param name
- paramValue- the param value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
setQueryParamHttpRequest<T> setQueryParam(String paramName, String paramValue) Set a query parameter to the request.- Parameters:
- paramName- the param name
- paramValue- the param value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
setTemplateParamHttpRequest<T> setTemplateParam(String paramName, String paramValue) Set a request URI template string parameter to the request, expanded when the request URI is aUriTemplate.- Parameters:
- paramName- the param name
- paramValue- the param value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
setTemplateParamHttpRequest<T> setTemplateParam(String paramName, List<String> paramValue) Set a request URI template list parameter to the request, expanded when the request URI is aUriTemplate.- Parameters:
- paramName- the param name
- paramValue- the param value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
setTemplateParamHttpRequest<T> setTemplateParam(String paramName, Map<String,String> paramValue) Set a request URI template map parameter to the request, expanded when the request URI is aUriTemplate.- Parameters:
- paramName- the param name
- paramValue- the param value
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
followRedirectsHttpRequest<T> followRedirects(boolean value) Set whether to follow request redirections- Parameters:
- value- true if redirections should be followed
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
followRedirectsboolean followRedirects() - Returns:
- whether to follow request redirections
 
 - 
routingKeyHttpRequest<T> routingKey(String key) Set the routing key, the routing key can be used by a Vert.x client side sticky load balancer to pin the request to a remote HTTP server.- Parameters:
- key- the routing key
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
routingKeyString routingKey() Return the routing key, the routing key can be used by a Vert.x client side sticky load balancer to pin the request to a remote HTTP server.- Returns:
- the routing key
 
 - 
proxyHttpRequest<T> proxy(ProxyOptions proxyOptions) Configure the request to set a proxy for this request. Setting proxy here supersedes the proxy set on the client itself- Parameters:
- proxyOptions- The proxy options
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
proxyProxyOptions proxy() - Returns:
- the proxy for this request
 
 - 
queryParamsMultiMap queryParams() Return the current query parameters.- Returns:
- the current query parameters
 
 - 
templateParamsVariables templateParams() Return the current request URI template parameters.- Returns:
- the current request URI template parameters
 
 - 
copyHttpRequest<T> copy() Copy this request- Returns:
- a copy of this request
 
 - 
multipartMixedHttpRequest<T> multipartMixed(boolean allow) Allow or disallow multipart mixed encoding when sendingMultipartFormhaving files sharing the same file name.
 The default value istrue.
 Set tofalseif you want to achieve the behavior for HTML5.- Parameters:
- allow-- trueallows use of multipart mixed encoding
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
multipartMixedboolean multipartMixed() - Returns:
- whether multipart mixed encoding is allowed
 
 - 
traceOperationHttpRequest<T> traceOperation(String traceOperation) Trace operation name override.- Parameters:
- traceOperation- Name of operation to use in traces
- Returns:
- a reference to this, so the API can be used fluently
 
 - 
traceOperationString traceOperation() - Returns:
- the trace operation name override
 
 - 
sendStreamFuture<HttpResponse<T>> sendStream(ReadStream<Buffer> body) Likesend()but with an HTTP requestbodystream.- Parameters:
- body- the body
- See Also:
- sendStream(ReadStream)
 
 - 
sendBufferFuture<HttpResponse<T>> sendBuffer(Buffer body) Likesend()but with an HTTP requestbodybuffer.- Parameters:
- body- the body
- See Also:
- sendBuffer(Buffer)
 
 - 
sendJsonObjectFuture<HttpResponse<T>> sendJsonObject(JsonObject body) Likesend()but with an HTTP requestbodyobject encoded as json and the content type set toapplication/json.- Parameters:
- body- the body
- See Also:
- sendJsonObject(JsonObject)
 
 - 
sendJsonFuture<HttpResponse<T>> sendJson(Object body) Likesend()but with an HTTP requestbodyobject encoded as json and the content type set toapplication/json.- Parameters:
- body- the body
- See Also:
- sendJson(Object)
 
 - 
sendFormFuture<HttpResponse<T>> sendForm(MultiMap body) Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set toapplication/x-www-form-urlencoded.When the content type header is previously set to multipart/form-datait will be used instead.- Parameters:
- body- the body
- See Also:
- sendForm(MultiMap)
 
 - 
sendFormFuture<HttpResponse<T>> sendForm(MultiMap body, String charset) Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set toapplication/x-www-form-urlencoded.When the content type header is previously set to multipart/form-datait will be used instead. NOTE: the use of this method is strongly discouraged to use when the form is aapplication/x-www-form-urlencodedencoded form since the charset to use must be UTF-8.- Parameters:
- body- the body
- charset- the charset
- See Also:
- sendForm(MultiMap, String)
 
 - 
sendMultipartFormFuture<HttpResponse<T>> sendMultipartForm(MultipartForm body) Likesend()but with an HTTP requestbodymultimap encoded as form and the content type set tomultipart/form-data. You may use this method to send attributes and upload files.- Parameters:
- body- the body
- See Also:
- sendMultipartForm(MultipartForm)
 
 - 
sendFuture<HttpResponse<T>> send() Send a request, thehandlerwill receive the response as anHttpResponse.- See Also:
- send()
 
 
- 
 
-