HTTPCLIENT-1379: added X509HostnameVerifier setter to HttpClientBuilder
git-svn-id: https://svn.apache.org/repos/asf/httpcomponents/httpclient/trunk@1498955 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
47f900a03f
commit
efe3d7d7e2
27
httpclient/src/main/java/org/apache/http/impl/client/HttpClientBuilder.java
Normal file → Executable file
27
httpclient/src/main/java/org/apache/http/impl/client/HttpClientBuilder.java
Normal file → Executable file
|
@ -74,7 +74,9 @@ import org.apache.http.conn.routing.HttpRoutePlanner;
|
||||||
import org.apache.http.conn.socket.ConnectionSocketFactory;
|
import org.apache.http.conn.socket.ConnectionSocketFactory;
|
||||||
import org.apache.http.conn.socket.LayeredConnectionSocketFactory;
|
import org.apache.http.conn.socket.LayeredConnectionSocketFactory;
|
||||||
import org.apache.http.conn.socket.PlainSocketFactory;
|
import org.apache.http.conn.socket.PlainSocketFactory;
|
||||||
|
import org.apache.http.conn.ssl.SSLContexts;
|
||||||
import org.apache.http.conn.ssl.SSLSocketFactory;
|
import org.apache.http.conn.ssl.SSLSocketFactory;
|
||||||
|
import org.apache.http.conn.ssl.X509HostnameVerifier;
|
||||||
import org.apache.http.cookie.CookieSpecProvider;
|
import org.apache.http.cookie.CookieSpecProvider;
|
||||||
import org.apache.http.impl.DefaultConnectionReuseStrategy;
|
import org.apache.http.impl.DefaultConnectionReuseStrategy;
|
||||||
import org.apache.http.impl.NoConnectionReuseStrategy;
|
import org.apache.http.impl.NoConnectionReuseStrategy;
|
||||||
|
@ -107,6 +109,7 @@ import org.apache.http.protocol.HttpRequestExecutor;
|
||||||
import org.apache.http.protocol.RequestContent;
|
import org.apache.http.protocol.RequestContent;
|
||||||
import org.apache.http.protocol.RequestTargetHost;
|
import org.apache.http.protocol.RequestTargetHost;
|
||||||
import org.apache.http.protocol.RequestUserAgent;
|
import org.apache.http.protocol.RequestUserAgent;
|
||||||
|
import org.apache.http.util.TextUtils;
|
||||||
import org.apache.http.util.VersionInfo;
|
import org.apache.http.util.VersionInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -141,6 +144,7 @@ import org.apache.http.util.VersionInfo;
|
||||||
public class HttpClientBuilder {
|
public class HttpClientBuilder {
|
||||||
|
|
||||||
private HttpRequestExecutor requestExec;
|
private HttpRequestExecutor requestExec;
|
||||||
|
private X509HostnameVerifier hostnameVerifier;
|
||||||
private LayeredConnectionSocketFactory sslSocketFactory;
|
private LayeredConnectionSocketFactory sslSocketFactory;
|
||||||
private SSLContext sslcontext;
|
private SSLContext sslcontext;
|
||||||
private HttpClientConnectionManager connManager;
|
private HttpClientConnectionManager connManager;
|
||||||
|
@ -200,6 +204,11 @@ public class HttpClientBuilder {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public final HttpClientBuilder setHostnameVerifier(final X509HostnameVerifier hostnameVerifier) {
|
||||||
|
this.hostnameVerifier = hostnameVerifier;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
public final HttpClientBuilder setSSLSocketFactory(
|
public final HttpClientBuilder setSSLSocketFactory(
|
||||||
final LayeredConnectionSocketFactory sslSocketFactory) {
|
final LayeredConnectionSocketFactory sslSocketFactory) {
|
||||||
this.sslSocketFactory = sslSocketFactory;
|
this.sslSocketFactory = sslSocketFactory;
|
||||||
|
@ -449,6 +458,12 @@ public class HttpClientBuilder {
|
||||||
closeables.add(closeable);
|
closeables.add(closeable);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static String[] split(final String s) {
|
||||||
|
if (TextUtils.isBlank(s)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return s.split(" *, *");
|
||||||
|
}
|
||||||
|
|
||||||
public CloseableHttpClient build() {
|
public CloseableHttpClient build() {
|
||||||
// Create main request executor
|
// Create main request executor
|
||||||
|
@ -461,12 +476,18 @@ public class HttpClientBuilder {
|
||||||
LayeredConnectionSocketFactory sslSocketFactory = this.sslSocketFactory;
|
LayeredConnectionSocketFactory sslSocketFactory = this.sslSocketFactory;
|
||||||
if (sslSocketFactory == null) {
|
if (sslSocketFactory == null) {
|
||||||
if (sslcontext != null) {
|
if (sslcontext != null) {
|
||||||
sslSocketFactory = new SSLSocketFactory(sslcontext);
|
sslSocketFactory = new SSLSocketFactory(sslcontext, hostnameVerifier);
|
||||||
} else {
|
} else {
|
||||||
if (systemProperties) {
|
if (systemProperties) {
|
||||||
sslSocketFactory = SSLSocketFactory.getSystemSocketFactory();
|
sslSocketFactory = new SSLSocketFactory(
|
||||||
|
(javax.net.ssl.SSLSocketFactory) javax.net.ssl.SSLSocketFactory.getDefault(),
|
||||||
|
split(System.getProperty("https.protocols")),
|
||||||
|
split(System.getProperty("https.cipherSuites")),
|
||||||
|
hostnameVerifier);
|
||||||
} else {
|
} else {
|
||||||
sslSocketFactory = SSLSocketFactory.getSocketFactory();
|
sslSocketFactory = new SSLSocketFactory(
|
||||||
|
SSLContexts.createDefault(),
|
||||||
|
hostnameVerifier);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue