提交 4acc0be8 编写于 作者: C coffeys

8065994: HTTP Tunnel connection to NTLM proxy reauthenticates instead of using keep-alive

Reviewed-by: chegar
上级 9d21d01b
...@@ -192,22 +192,6 @@ final class HttpsClient extends HttpClient ...@@ -192,22 +192,6 @@ final class HttpsClient extends HttpClient
return userAgent; return userAgent;
} }
// should remove once HttpClient.newHttpProxy is putback
private static Proxy newHttpProxy(String proxyHost, int proxyPort) {
InetSocketAddress saddr = null;
final String phost = proxyHost;
final int pport = proxyPort < 0 ? httpsPortNumber : proxyPort;
try {
saddr = java.security.AccessController.doPrivileged(new
java.security.PrivilegedExceptionAction<InetSocketAddress>() {
public InetSocketAddress run() {
return new InetSocketAddress(phost, pport);
}});
} catch (java.security.PrivilegedActionException pae) {
}
return new Proxy(Proxy.Type.HTTP, saddr);
}
// CONSTRUCTOR, FACTORY // CONSTRUCTOR, FACTORY
...@@ -251,7 +235,7 @@ final class HttpsClient extends HttpClient ...@@ -251,7 +235,7 @@ final class HttpsClient extends HttpClient
throws IOException { throws IOException {
this(sf, url, this(sf, url,
(proxyHost == null? null: (proxyHost == null? null:
HttpsClient.newHttpProxy(proxyHost, proxyPort)), HttpClient.newHttpProxy(proxyHost, proxyPort, "https")),
connectTimeout); connectTimeout);
} }
...@@ -261,6 +245,11 @@ final class HttpsClient extends HttpClient ...@@ -261,6 +245,11 @@ final class HttpsClient extends HttpClient
HttpsClient(SSLSocketFactory sf, URL url, Proxy proxy, HttpsClient(SSLSocketFactory sf, URL url, Proxy proxy,
int connectTimeout) int connectTimeout)
throws IOException { throws IOException {
PlatformLogger logger = HttpURLConnection.getHttpLogger();
if (logger.isLoggable(PlatformLogger.Level.FINEST)) {
logger.finest("Creating new HttpsClient with url:" + url + " and proxy:" + proxy +
" with connect timeout:" + connectTimeout);
}
this.proxy = proxy; this.proxy = proxy;
setSSLSocketFactory(sf); setSSLSocketFactory(sf);
this.proxyDisabled = true; this.proxyDisabled = true;
...@@ -317,7 +306,7 @@ final class HttpsClient extends HttpClient ...@@ -317,7 +306,7 @@ final class HttpsClient extends HttpClient
return HttpsClient.New(sf, url, hv, return HttpsClient.New(sf, url, hv,
(proxyHost == null? null : (proxyHost == null? null :
HttpsClient.newHttpProxy(proxyHost, proxyPort)), HttpClient.newHttpProxy(proxyHost, proxyPort, "https")),
useCache, connectTimeout, httpuc); useCache, connectTimeout, httpuc);
} }
...@@ -329,6 +318,11 @@ final class HttpsClient extends HttpClient ...@@ -329,6 +318,11 @@ final class HttpsClient extends HttpClient
if (p == null) { if (p == null) {
p = Proxy.NO_PROXY; p = Proxy.NO_PROXY;
} }
PlatformLogger logger = HttpURLConnection.getHttpLogger();
if (logger.isLoggable(PlatformLogger.Level.FINEST)) {
logger.finest("Looking for HttpClient for URL " + url +
" and proxy value of " + p);
}
HttpsClient ret = null; HttpsClient ret = null;
if (useCache) { if (useCache) {
/* see if one's already around */ /* see if one's already around */
...@@ -342,14 +336,13 @@ final class HttpsClient extends HttpClient ...@@ -342,14 +336,13 @@ final class HttpsClient extends HttpClient
if (ret != null) { if (ret != null) {
if ((ret.proxy != null && ret.proxy.equals(p)) || if ((ret.proxy != null && ret.proxy.equals(p)) ||
(ret.proxy == null && p == null)) { (ret.proxy == null && p == Proxy.NO_PROXY)) {
synchronized (ret) { synchronized (ret) {
ret.cachedHttpClient = true; ret.cachedHttpClient = true;
assert ret.inCache; assert ret.inCache;
ret.inCache = false; ret.inCache = false;
if (httpuc != null && ret.needsTunneling()) if (httpuc != null && ret.needsTunneling())
httpuc.setTunnelState(TUNNELING); httpuc.setTunnelState(TUNNELING);
PlatformLogger logger = HttpURLConnection.getHttpLogger();
if (logger.isLoggable(PlatformLogger.Level.FINEST)) { if (logger.isLoggable(PlatformLogger.Level.FINEST)) {
logger.finest("KeepAlive stream retrieved from the cache, " + ret); logger.finest("KeepAlive stream retrieved from the cache, " + ret);
} }
...@@ -360,6 +353,9 @@ final class HttpsClient extends HttpClient ...@@ -360,6 +353,9 @@ final class HttpsClient extends HttpClient
// This should be fine as it is very rare that a connection // This should be fine as it is very rare that a connection
// to the same host will not use the same proxy. // to the same host will not use the same proxy.
synchronized(ret) { synchronized(ret) {
if (logger.isLoggable(PlatformLogger.Level.FINEST)) {
logger.finest("Not returning this connection to cache: " + ret);
}
ret.inCache = false; ret.inCache = false;
ret.closeServer(); ret.closeServer();
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册