From 8e5af26326a806ec8d33c14e7651795ea7250223 Mon Sep 17 00:00:00 2001 From: Michael McMahon Date: Mon, 16 Dec 2019 15:13:19 +0000 Subject: [PATCH] 8234825: Better Headings for HTTP Servers Reviewed-by: chegar, dfuchs, igerasim --- .../com/sun/net/httpserver/Headers.java | 34 +++++++++++++++++-- 1 file changed, 32 insertions(+), 2 deletions(-) diff --git a/src/jdk.httpserver/share/classes/com/sun/net/httpserver/Headers.java b/src/jdk.httpserver/share/classes/com/sun/net/httpserver/Headers.java index 2569060aa47..f41845f7112 100644 --- a/src/jdk.httpserver/share/classes/com/sun/net/httpserver/Headers.java +++ b/src/jdk.httpserver/share/classes/com/sun/net/httpserver/Headers.java @@ -82,11 +82,14 @@ public class Headers implements Map> { char[] b = key.toCharArray(); if (b[0] >= 'a' && b[0] <= 'z') { b[0] = (char)(b[0] - ('a' - 'A')); - } + } else if (b[0] == '\r' || b[0] == '\n') + throw new IllegalArgumentException("illegal character in key"); + for (int i=1; i= 'A' && b[i] <= 'Z') { b[i] = (char) (b[i] + ('a' - 'A')); - } + } else if (b[i] == '\r' || b[i] == '\n') + throw new IllegalArgumentException("illegal character in key"); } return new String(b); } @@ -128,6 +131,8 @@ public class Headers implements Map> { } public List put(String key, List value) { + for (String v : value) + checkValue(v); return map.put (normalize(key), value); } @@ -139,6 +144,7 @@ public class Headers implements Map> { * @param value the header value to add to the header */ public void add (String key, String value) { + checkValue(value); String k = normalize(key); List l = map.get(k); if (l == null) { @@ -148,6 +154,30 @@ public class Headers implements Map> { l.add (value); } + private static void checkValue(String value) { + int len = value.length(); + for (int i=0; i= len - 2) { + throw new IllegalArgumentException("Illegal CR found in header"); + } + char c1 = value.charAt(i+1); + char c2 = value.charAt(i+2); + if (c1 != '\n') { + throw new IllegalArgumentException("Illegal char found after CR in header"); + } + if (c2 != ' ' && c2 != '\t') { + throw new IllegalArgumentException("No whitespace found after CRLF in header"); + } + i+=2; + } else if (c == '\n') { + throw new IllegalArgumentException("Illegal LF found in header"); + } + } + } + /** * sets the given value as the sole header value * for the given key. If the mapping does not