Class CloseableHttpClient
- java.lang.Object
-
- org.apache.hc.client5.http.impl.classic.CloseableHttpClient
-
- All Implemented Interfaces:
java.io.Closeable
,java.lang.AutoCloseable
,HttpClient
,org.apache.hc.core5.io.ModalCloseable
- Direct Known Subclasses:
InternalHttpClient
,MinimalHttpClient
@Contract(threading=SAFE) public abstract class CloseableHttpClient extends java.lang.Object implements HttpClient, org.apache.hc.core5.io.ModalCloseable
Base implementation ofHttpClient
that also implementsModalCloseable
.- Since:
- 4.3
-
-
Field Summary
Fields Modifier and Type Field Description private static org.slf4j.Logger
LOG
-
Constructor Summary
Constructors Constructor Description CloseableHttpClient()
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Deprecated Methods Modifier and Type Method Description private static org.apache.hc.core5.http.HttpHost
determineTarget(org.apache.hc.core5.http.ClassicHttpRequest request)
protected abstract CloseableHttpResponse
doExecute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context)
CloseableHttpResponse
execute(org.apache.hc.core5.http.ClassicHttpRequest request)
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(ClassicHttpRequest, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client.<T> T
execute(org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler)
Executes a request using the default context and processes the response using the given response handler.CloseableHttpResponse
execute(org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context)
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client.<T> T
execute(org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler)
Executes a request using the default context and processes the response using the given response handler.CloseableHttpResponse
execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request)
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(HttpHost, ClassicHttpRequest, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client.<T> T
execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler)
Executes a request using the default context and processes the response using the given response handler.CloseableHttpResponse
execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context)
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(HttpHost, ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client.<T> T
execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler)
Executes a request using the default context and processes the response using the given response handler.-
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
-
Methods inherited from interface org.apache.hc.client5.http.classic.HttpClient
executeOpen
-
-
-
-
Method Detail
-
doExecute
protected abstract CloseableHttpResponse doExecute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context) throws java.io.IOException
- Throws:
java.io.IOException
-
determineTarget
private static org.apache.hc.core5.http.HttpHost determineTarget(org.apache.hc.core5.http.ClassicHttpRequest request) throws ClientProtocolException
- Throws:
ClientProtocolException
-
execute
@Deprecated public CloseableHttpResponse execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context) throws java.io.IOException
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(HttpHost, ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client. For special cases one can still useHttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
to keep the response object open after the request execution.Description copied from interface:HttpClient
Executes HTTP request using the given context.- Specified by:
execute
in interfaceHttpClient
- Parameters:
target
- the target host for the request. Implementations may acceptnull
if 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, ornull
to 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:
java.io.IOException
- in case of a problem or the connection was aborted- See Also:
execute(HttpHost, ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
,HttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
-
execute
@Deprecated public CloseableHttpResponse execute(org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context) throws java.io.IOException
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client. For special cases one can still useHttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
to keep the response object open after the request execution.Description copied from interface:HttpClient
Executes HTTP request using the given context.- Specified by:
execute
in interfaceHttpClient
- Parameters:
request
- the request to executecontext
- the context to use for the execution, ornull
to 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:
java.io.IOException
- in case of a problem or the connection was aborted- See Also:
execute(ClassicHttpRequest, HttpContext, HttpClientResponseHandler)
,HttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
-
execute
@Deprecated public CloseableHttpResponse execute(org.apache.hc.core5.http.ClassicHttpRequest request) throws java.io.IOException
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(ClassicHttpRequest, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client. For special cases one can still useHttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
to keep the response object open after the request execution.Description copied from interface:HttpClient
Executes HTTP request using the default context.- Specified by:
execute
in 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:
java.io.IOException
- in case of a problem or the connection was aborted- See Also:
execute(ClassicHttpRequest, HttpClientResponseHandler)
,HttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
-
execute
@Deprecated public CloseableHttpResponse execute(org.apache.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request) throws java.io.IOException
Deprecated.It is strongly recommended to use execute methods withHttpClientResponseHandler
such asexecute(HttpHost, ClassicHttpRequest, HttpClientResponseHandler)
in order to ensure automatic resource deallocation by the client. For special cases one can still useHttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
to keep the response object open after the request execution.Description copied from interface:HttpClient
Executes HTTP request using the default context.- Specified by:
execute
in interfaceHttpClient
- Parameters:
target
- the target host for the request. Implementations may acceptnull
if 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:
java.io.IOException
- in case of a problem or the connection was aborted- See Also:
execute(HttpHost, ClassicHttpRequest, HttpClientResponseHandler)
,HttpClient.executeOpen(HttpHost, ClassicHttpRequest, HttpContext)
-
execute
public <T> T execute(org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler) throws java.io.IOException
Executes a request using the default context and processes the response using the given response handler. 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 individualHttpClientResponseHandler
s from having to manage resource deallocation internally.- Specified by:
execute
in interfaceHttpClient
- Parameters:
request
- the request to executeresponseHandler
- the response handler- Returns:
- the response object as generated by the response handler.
- Throws:
java.io.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.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler) throws java.io.IOException
Executes a request using the default context and processes the response using the given response handler. 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 individualHttpClientResponseHandler
s from having to manage resource deallocation internally.- Specified by:
execute
in interfaceHttpClient
- Parameters:
request
- the request to executeresponseHandler
- the response handlercontext
- the context to use for the execution, ornull
to use the default context- Returns:
- the response object as generated by the response handler.
- Throws:
java.io.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.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler) throws java.io.IOException
Executes a request using the default context and processes the response using the given response handler. 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 individualHttpClientResponseHandler
s from having to manage resource deallocation internally.- Specified by:
execute
in interfaceHttpClient
- Parameters:
target
- the target host for the request. Implementations may acceptnull
if 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:
java.io.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.hc.core5.http.HttpHost target, org.apache.hc.core5.http.ClassicHttpRequest request, org.apache.hc.core5.http.protocol.HttpContext context, org.apache.hc.core5.http.io.HttpClientResponseHandler<? extends T> responseHandler) throws java.io.IOException
Executes a request using the default context and processes the response using the given response handler. 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 individualHttpClientResponseHandler
s from having to manage resource deallocation internally.- Specified by:
execute
in interfaceHttpClient
- Parameters:
target
- the target host for the request. Implementations may acceptnull
if 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, ornull
to use the default contextresponseHandler
- the response handler- Returns:
- the response object as generated by the response handler.
- Throws:
java.io.IOException
- in case of a problem or the connection was abortedClientProtocolException
- in case of an http protocol error
-
-