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:
Oleg Kalnichevski 2013-07-02 14:32:47 +00:00
parent 47f900a03f
commit efe3d7d7e2
1 changed files with 24 additions and 3 deletions

View 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);
} }
} }
} }