From ff8e7d4087063a6d040c19079d28640993f07da8 Mon Sep 17 00:00:00 2001 From: Vyom Tewari Date: Sat, 7 Mar 2020 18:35:20 +0530 Subject: [PATCH] 8238579: HttpsURLConnection drops the timeout and hangs forever in read HttpsURLConnection drops the timeout and hangs forever in read Reviewed-by: dfuchs --- .../AbstractDelegateHttpsURLConnection.java | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/src/java.base/share/classes/sun/net/www/protocol/https/AbstractDelegateHttpsURLConnection.java b/src/java.base/share/classes/sun/net/www/protocol/https/AbstractDelegateHttpsURLConnection.java index f14f3f02867..3828eb3cd29 100644 --- a/src/java.base/share/classes/sun/net/www/protocol/https/AbstractDelegateHttpsURLConnection.java +++ b/src/java.base/share/classes/sun/net/www/protocol/https/AbstractDelegateHttpsURLConnection.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2001, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2001, 2020, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it @@ -87,10 +87,16 @@ public abstract class AbstractDelegateHttpsURLConnection extends */ public void setNewClient (URL url, boolean useCache) throws IOException { + int readTimeout = getReadTimeout(); http = HttpsClient.New (getSSLSocketFactory(), url, getHostnameVerifier(), - useCache, this); + null, + -1, + useCache, + getConnectTimeout(), + this); + http.setReadTimeout(readTimeout); ((HttpsClient)http).afterConnect(); } @@ -132,10 +138,16 @@ public abstract class AbstractDelegateHttpsURLConnection extends boolean useCache) throws IOException { if (connected) return; + int readTimeout = getReadTimeout(); http = HttpsClient.New (getSSLSocketFactory(), url, getHostnameVerifier(), - proxyHost, proxyPort, useCache, this); + proxyHost, + proxyPort, + useCache, + getConnectTimeout(), + this); + http.setReadTimeout(readTimeout); connected = true; }