From 26ac8366360685ef0cf3447ee7db16ba7a7fa1ec Mon Sep 17 00:00:00 2001 From: Michael McMahon Date: Thu, 13 Oct 2022 08:32:48 +0000 Subject: [PATCH] 8291638: Keep-Alive timeout of 0 should close connection immediately Reviewed-by: dfuchs, jpai --- .../classes/sun/net/www/HeaderParser.java | 16 +++++++++++++++- .../classes/sun/net/www/http/HttpClient.java | 18 ++++++++++++++---- .../sun/net/www/http/KeepAliveCache.java | 2 ++ .../net/www/http/HttpClient/KeepAliveTest.java | 7 +------ 4 files changed, 32 insertions(+), 11 deletions(-) diff --git a/src/java.base/share/classes/sun/net/www/HeaderParser.java b/src/java.base/share/classes/sun/net/www/HeaderParser.java index a4b2ab50497..e6d7435a458 100644 --- a/src/java.base/share/classes/sun/net/www/HeaderParser.java +++ b/src/java.base/share/classes/sun/net/www/HeaderParser.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 1996, 2011, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 1996, 2022, 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 @@ -26,6 +26,7 @@ package sun.net.www; import java.util.Iterator; +import java.util.OptionalInt; /* This is useful for the nightmare of parsing multi-part HTTP/RFC822 headers * sensibly: @@ -246,6 +247,19 @@ public class HeaderParser { return Default; } } + + public OptionalInt findInt(String k) { + try { + String s = findValue(k); + if (s == null) { + return OptionalInt.empty(); + } + return OptionalInt.of(Integer.parseInt(s)); + } catch (Throwable t) { + return OptionalInt.empty(); + } + } + /* public static void main(String[] a) throws Exception { System.out.print("enter line to parse> "); diff --git a/src/java.base/share/classes/sun/net/www/http/HttpClient.java b/src/java.base/share/classes/sun/net/www/http/HttpClient.java index 3e23f11a6d0..e6dd88c15b9 100644 --- a/src/java.base/share/classes/sun/net/www/http/HttpClient.java +++ b/src/java.base/share/classes/sun/net/www/http/HttpClient.java @@ -29,6 +29,7 @@ import java.io.*; import java.net.*; import java.util.Locale; import java.util.Objects; +import java.util.OptionalInt; import java.util.Properties; import java.util.concurrent.locks.ReentrantLock; @@ -127,6 +128,7 @@ public class HttpClient extends NetworkClient { * 0: the server specified no keep alive headers * -1: the server provided "Connection: keep-alive" but did not specify a * a particular time in a "Keep-Alive:" headers + * -2: the server provided "Connection: keep-alive" and timeout=0 * Positive values are the number of seconds specified by the server * in a "Keep-Alive" header */ @@ -903,11 +905,19 @@ public class HttpClient extends NetworkClient { if (keepAliveConnections < 0) { keepAliveConnections = usingProxy?50:5; } - keepAliveTimeout = p.findInt("timeout", -1); - if (keepAliveTimeout < -1) { - // if the server specified a negative (invalid) value - // then we set to -1, which is equivalent to no value + OptionalInt timeout = p.findInt("timeout"); + if (timeout.isEmpty()) { keepAliveTimeout = -1; + } else { + keepAliveTimeout = timeout.getAsInt(); + if (keepAliveTimeout < 0) { + // if the server specified a negative (invalid) value + // then we set to -1, which is equivalent to no value + keepAliveTimeout = -1; + } else if (keepAliveTimeout == 0) { + // handled specially to mean close connection immediately + keepAliveTimeout = -2; + } } } } else if (b[7] != '0') { diff --git a/src/java.base/share/classes/sun/net/www/http/KeepAliveCache.java b/src/java.base/share/classes/sun/net/www/http/KeepAliveCache.java index b14deacf63e..4080dab8469 100644 --- a/src/java.base/share/classes/sun/net/www/http/KeepAliveCache.java +++ b/src/java.base/share/classes/sun/net/www/http/KeepAliveCache.java @@ -173,6 +173,8 @@ public class KeepAliveCache // different default for server and proxy keepAliveTimeout = http.getUsingProxy() ? 60 : 5; } + } else if (keepAliveTimeout == -2) { + keepAliveTimeout = 0; } // at this point keepAliveTimeout is the number of seconds to keep // alive, which could be 0, if the user specified 0 for the property diff --git a/test/jdk/sun/net/www/http/HttpClient/KeepAliveTest.java b/test/jdk/sun/net/www/http/HttpClient/KeepAliveTest.java index d768c007d32..4373793ac98 100644 --- a/test/jdk/sun/net/www/http/HttpClient/KeepAliveTest.java +++ b/test/jdk/sun/net/www/http/HttpClient/KeepAliveTest.java @@ -24,6 +24,7 @@ /* * @test * @library /test/lib + * @bug 8291226 8291638 * @modules java.base/sun.net:+open * java.base/sun.net.www.http:+open * java.base/sun.net.www:+open @@ -1015,12 +1016,6 @@ public class KeepAliveTest { } private void startScenario(int scenarioNumber) throws Exception { - //test scenarios are skipped because of JDK-8291638 - if((scenarioNumber >= 112 && scenarioNumber <= 127) || (scenarioNumber >= 144 && scenarioNumber <= 159)) { - System.out.println("Scenario Skipped:"+scenarioNumber); - this.countDownLatch.countDown(); - return; - } System.out.println("serverScenarios[" + scenarioNumber + "]=" + getServerScenario(scenarioNumber)); System.out.println("clientScenarios[" + scenarioNumber + "]=" + clientScenarios[getClientScenarioNumber(scenarioNumber)]); if(expectedValues[scenarioNumber] == 0) {