Class DecompressingHttpClient
- All Implemented Interfaces:
HttpClient
Decorator adding support for compressed responses. This class sets
the Accept-Encoding header on requests to indicate
support for the gzip and deflate
compression schemes; it then checks the Content-Encoding
header on the response to uncompress any compressed response bodies.
The InputStream of the entity will contain the uncompressed
content.
N.B. Any upstream clients of this class need to be aware that
this effectively obscures visibility into the length of a server
response body, since the Content-Length header will
correspond to the compressed entity length received from the server,
but the content length experienced by reading the response body may
be different (hopefully higher!).
That said, this decorator is compatible with the
CachingHttpClient in that the two decorators can be added
in either order and still have cacheable responses be cached.
- Since:
- 4.2
-
Field Summary
FieldsModifier and TypeFieldDescriptionprivate final org.apache.http.HttpRequestInterceptorDeprecated.private final HttpClientDeprecated.private final org.apache.http.HttpResponseInterceptorDeprecated. -
Constructor Summary
ConstructorsConstructorDescriptionDeprecated.Constructs a decorator to ask for and handle compressed entities on the fly.DecompressingHttpClient(HttpClient backend) Deprecated.Constructs a decorator to ask for and handle compressed entities on the fly.DecompressingHttpClient(HttpClient backend, org.apache.http.HttpRequestInterceptor requestInterceptor, org.apache.http.HttpResponseInterceptor responseInterceptor) Deprecated. -
Method Summary
Modifier and TypeMethodDescriptionorg.apache.http.HttpResponseexecute(HttpUriRequest request) Deprecated.Executes HTTP request using the default context.<T> Texecute(HttpUriRequest request, ResponseHandler<? extends T> responseHandler) Deprecated.Executes HTTP request using the default context and processes the response using the given response handler.<T> Texecute(HttpUriRequest request, ResponseHandler<? extends T> responseHandler, org.apache.http.protocol.HttpContext context) Deprecated.Executes HTTP request using the given context and processes the response using the given response handler.org.apache.http.HttpResponseexecute(HttpUriRequest request, org.apache.http.protocol.HttpContext context) Deprecated.Executes HTTP request using the given context.org.apache.http.HttpResponseexecute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request) Deprecated.Executes HTTP request using the default context.<T> Texecute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, ResponseHandler<? extends T> responseHandler) Deprecated.Executes HTTP request to the target using the default context and processes the response using the given response handler.<T> Texecute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, ResponseHandler<? extends T> responseHandler, org.apache.http.protocol.HttpContext context) Deprecated.Executes HTTP request to the target using the given context and processes the response using the given response handler.org.apache.http.HttpResponseexecute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, org.apache.http.protocol.HttpContext context) Deprecated.Executes HTTP request using the given context.Deprecated.Obtains the connection manager used by this client.Deprecated.Gets the HttpClient to issue request.(package private) org.apache.http.HttpHostgetHttpHost(HttpUriRequest request) Deprecated.org.apache.http.params.HttpParamsDeprecated.Obtains the parameters for this client.
-
Field Details
-
backend
Deprecated. -
acceptEncodingInterceptor
private final org.apache.http.HttpRequestInterceptor acceptEncodingInterceptorDeprecated. -
contentEncodingInterceptor
private final org.apache.http.HttpResponseInterceptor contentEncodingInterceptorDeprecated.
-
-
Constructor Details
-
DecompressingHttpClient
public DecompressingHttpClient()Deprecated.Constructs a decorator to ask for and handle compressed entities on the fly. -
DecompressingHttpClient
Deprecated.Constructs a decorator to ask for and handle compressed entities on the fly.- Parameters:
backend- theHttpClientto use for actually issuing requests
-
DecompressingHttpClient
DecompressingHttpClient(HttpClient backend, org.apache.http.HttpRequestInterceptor requestInterceptor, org.apache.http.HttpResponseInterceptor responseInterceptor) Deprecated.
-
-
Method Details
-
getParams
public org.apache.http.params.HttpParams getParams()Deprecated.Description copied from interface:HttpClientObtains the parameters for this client. These parameters will become defaults for all requests being executed with this client, and for the parameters of dependent objects in this client.- Specified by:
getParamsin interfaceHttpClient- Returns:
- the default parameters
-
getConnectionManager
Deprecated.Description copied from interface:HttpClientObtains the connection manager used by this client.- Specified by:
getConnectionManagerin interfaceHttpClient- Returns:
- the connection manager
-
execute
public org.apache.http.HttpResponse execute(HttpUriRequest request) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the default context.- Specified by:
executein interfaceHttpClient- Parameters:
request- the request to execute- Returns:
- the response to the request. This is always a final response, never an intermediate response with an 1xx status code. Whether redirects or authentication challenges will be returned or handled automatically depends on the implementation and configuration of this client.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
getHttpClient
Deprecated.Gets the HttpClient to issue request.- Returns:
- the HttpClient to issue request
-
getHttpHost
Deprecated. -
execute
public org.apache.http.HttpResponse execute(HttpUriRequest request, org.apache.http.protocol.HttpContext context) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the given context.- Specified by:
executein interfaceHttpClient- Parameters:
request- the request to executecontext- the context to use for the execution, ornullto use the default context- Returns:
- the response to the request. This is always a final response, never an intermediate response with an 1xx status code. Whether redirects or authentication challenges will be returned or handled automatically depends on the implementation and configuration of this client.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public org.apache.http.HttpResponse execute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the default context.- Specified by:
executein interfaceHttpClient- Parameters:
target- the target host for the request. Implementations may acceptnullif they can still determine a route, for example to a default target or by inspecting the request.request- the request to execute- Returns:
- the response to the request. This is always a final response, never an intermediate response with an 1xx status code. Whether redirects or authentication challenges will be returned or handled automatically depends on the implementation and configuration of this client.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public org.apache.http.HttpResponse execute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, org.apache.http.protocol.HttpContext context) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the given context.- Specified by:
executein interfaceHttpClient- Parameters:
target- the target host for the request. Implementations may acceptnullif they can still determine a route, for example to a default target or by inspecting the request.request- the request to executecontext- the context to use for the execution, ornullto use the default context- Returns:
- the response to the request. This is always a final response, never an intermediate response with an 1xx status code. Whether redirects or authentication challenges will be returned or handled automatically depends on the implementation and configuration of this client.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public <T> T execute(HttpUriRequest request, ResponseHandler<? extends T> responseHandler) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the default context and processes the response using the given response handler.Implementing classes are required to ensure that the content entity associated with the response is fully consumed and the underlying connection is released back to the connection manager automatically in all cases relieving individual
ResponseHandlers from having to manage resource deallocation internally.- Specified by:
executein interfaceHttpClient- Parameters:
request- the request to executeresponseHandler- the response handler- Returns:
- the response object as generated by the response handler.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public <T> T execute(HttpUriRequest request, ResponseHandler<? extends T> responseHandler, org.apache.http.protocol.HttpContext context) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request using the given context and processes the response using the given response handler.Implementing classes are required to ensure that the content entity associated with the response is fully consumed and the underlying connection is released back to the connection manager automatically in all cases relieving individual
ResponseHandlers from having to manage resource deallocation internally.- Specified by:
executein interfaceHttpClient- Parameters:
request- the request to executeresponseHandler- the response handlercontext- the context to use for the execution, ornullto use the default context- Returns:
- the response object as generated by the response handler.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public <T> T execute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, ResponseHandler<? extends T> responseHandler) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request to the target using the default context and processes the response using the given response handler.Implementing classes are required to ensure that the content entity associated with the response is fully consumed and the underlying connection is released back to the connection manager automatically in all cases relieving individual
ResponseHandlers from having to manage resource deallocation internally.- Specified by:
executein interfaceHttpClient- Parameters:
target- the target host for the request. Implementations may acceptnullif they can still determine a route, for example to a default target or by inspecting the request.request- the request to executeresponseHandler- the response handler- Returns:
- the response object as generated by the response handler.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
execute
public <T> T execute(org.apache.http.HttpHost target, org.apache.http.HttpRequest request, ResponseHandler<? extends T> responseHandler, org.apache.http.protocol.HttpContext context) throws IOException, ClientProtocolException Deprecated.Description copied from interface:HttpClientExecutes HTTP request to the target using the given context and processes the response using the given response handler.Implementing classes are required to ensure that the content entity associated with the response is fully consumed and the underlying connection is released back to the connection manager automatically in all cases relieving individual
ResponseHandlers from having to manage resource deallocation internally.- Specified by:
executein interfaceHttpClient- Parameters:
target- the target host for the request. Implementations may acceptnullif they can still determine a route, for example to a default target or by inspecting the request.request- the request to executeresponseHandler- the response handlercontext- the context to use for the execution, ornullto use the default context- Returns:
- the response object as generated by the response handler.
- Throws:
IOException- in case of a problem or the connection was abortedClientProtocolException- in case of an http protocol error
-
HttpClientBuilder