7183292: HttpURLConnection.getHeaderFields() throws IllegalArgumentException: Illegal cookie name
Reviewed-by: khazra, chegar
This commit is contained in:
parent
811a20ee54
commit
94f61c976b
@ -137,7 +137,7 @@ public final class HttpCookie implements Cloneable {
|
|||||||
|
|
||||||
private HttpCookie(String name, String value, String header) {
|
private HttpCookie(String name, String value, String header) {
|
||||||
name = name.trim();
|
name = name.trim();
|
||||||
if (name.length() == 0 || !isToken(name) || isReserved(name)) {
|
if (name.length() == 0 || !isToken(name)) {
|
||||||
throw new IllegalArgumentException("Illegal cookie name");
|
throw new IllegalArgumentException("Illegal cookie name");
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -781,33 +781,6 @@ public final class HttpCookie implements Cloneable {
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* @param name
|
|
||||||
* the name to be tested
|
|
||||||
*
|
|
||||||
* @return {@code true} if the name is reserved by cookie specification,
|
|
||||||
* {@code false} if it is not
|
|
||||||
*/
|
|
||||||
private static boolean isReserved(String name) {
|
|
||||||
if (name.equalsIgnoreCase("Comment")
|
|
||||||
|| name.equalsIgnoreCase("CommentURL") // rfc2965 only
|
|
||||||
|| name.equalsIgnoreCase("Discard") // rfc2965 only
|
|
||||||
|| name.equalsIgnoreCase("Domain")
|
|
||||||
|| name.equalsIgnoreCase("Expires") // netscape draft only
|
|
||||||
|| name.equalsIgnoreCase("Max-Age")
|
|
||||||
|| name.equalsIgnoreCase("Path")
|
|
||||||
|| name.equalsIgnoreCase("Port") // rfc2965 only
|
|
||||||
|| name.equalsIgnoreCase("Secure")
|
|
||||||
|| name.equalsIgnoreCase("Version")
|
|
||||||
|| name.equalsIgnoreCase("HttpOnly")
|
|
||||||
|| name.charAt(0) == '$')
|
|
||||||
{
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Parse header string to cookie object.
|
* Parse header string to cookie object.
|
||||||
*
|
*
|
||||||
|
@ -243,10 +243,6 @@ public class TestHttpCookie {
|
|||||||
test("set-cookie2: Customer = \"WILE_E_COYOTE\"; Version = \"1\"; Path = \"/acme\"")
|
test("set-cookie2: Customer = \"WILE_E_COYOTE\"; Version = \"1\"; Path = \"/acme\"")
|
||||||
.n("Customer").v("WILE_E_COYOTE").ver(1).p("/acme");
|
.n("Customer").v("WILE_E_COYOTE").ver(1).p("/acme");
|
||||||
|
|
||||||
// $NAME is reserved; result should be null
|
|
||||||
test("set-cookie2: $Customer = \"WILE_E_COYOTE\"; Version = \"1\"; Path = \"/acme\"")
|
|
||||||
.nil();
|
|
||||||
|
|
||||||
// a 'full' cookie
|
// a 'full' cookie
|
||||||
test("set-cookie2: Customer=\"WILE_E_COYOTE\"" +
|
test("set-cookie2: Customer=\"WILE_E_COYOTE\"" +
|
||||||
";Version=\"1\"" +
|
";Version=\"1\"" +
|
||||||
|
74
jdk/test/java/net/HttpCookie/IllegalCookieNameTest.java
Normal file
74
jdk/test/java/net/HttpCookie/IllegalCookieNameTest.java
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (c) 2012, 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
|
||||||
|
* under the terms of the GNU General Public License version 2 only, as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
* This code is distributed in the hope that it will be useful, but WITHOUT
|
||||||
|
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
||||||
|
* version 2 for more details (a copy is included in the LICENSE file that
|
||||||
|
* accompanied this code).
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License version
|
||||||
|
* 2 along with this work; if not, write to the Free Software Foundation,
|
||||||
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
|
||||||
|
*
|
||||||
|
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
|
||||||
|
* or visit www.oracle.com if you need additional information or have any
|
||||||
|
* questions.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* @test
|
||||||
|
* @bug 7183292
|
||||||
|
*/
|
||||||
|
import java.net.*;
|
||||||
|
import java.util.*;
|
||||||
|
import java.io.*;
|
||||||
|
import com.sun.net.httpserver.*;
|
||||||
|
|
||||||
|
public class IllegalCookieNameTest {
|
||||||
|
public static void main(String[] args) throws IOException {
|
||||||
|
HttpServer s = null;
|
||||||
|
try {
|
||||||
|
InetSocketAddress addr = new InetSocketAddress(0);
|
||||||
|
s = HttpServer.create(addr, 10);
|
||||||
|
s.createContext("/", new HHandler());
|
||||||
|
s.start();
|
||||||
|
String u = "http://127.0.0.1:" + s.getAddress().getPort() + "/";
|
||||||
|
CookieHandler.setDefault(new TestCookieHandler());
|
||||||
|
URL url = new URL(u);
|
||||||
|
HttpURLConnection c = (HttpURLConnection) url.openConnection();
|
||||||
|
c.getHeaderFields();
|
||||||
|
System.out.println ("OK");
|
||||||
|
} finally {
|
||||||
|
s.stop(1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class TestCookieHandler extends CookieHandler {
|
||||||
|
@Override
|
||||||
|
public Map<String, List<String>> get(URI uri, Map<String, List<String>> requestHeaders) {
|
||||||
|
return new HashMap<String, List<String>>();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void put(URI uri, Map<String, List<String>> responseHeaders) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class HHandler implements HttpHandler {
|
||||||
|
public void handle (HttpExchange e) {
|
||||||
|
try {
|
||||||
|
Headers h = e.getResponseHeaders();
|
||||||
|
h.set ("Set-Cookie", "domain=; expires=Mon, 01-Jan-1990 00:00:00 GMT; path=/; domain=.foo.com");
|
||||||
|
e.sendResponseHeaders(200, -1);
|
||||||
|
e.close();
|
||||||
|
} catch (Exception ex) {
|
||||||
|
System.out.println (ex);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user