Ensure no null values are used when add/set headers.

Motivation:

We need to ensure we never allow to have null values set on headers, otherwise we will see a NPE during encoding them.

Modifications:

Add null check.

Result:

Correctly throw exception when a null header value is added/set
This commit is contained in:
Norman Maurer 2015-06-03 11:22:33 +02:00
parent 74c0f4ce14
commit de1f1a61f3
2 changed files with 15 additions and 3 deletions

View File

@ -29,6 +29,8 @@ import java.util.Map.Entry;
import java.util.NoSuchElementException; import java.util.NoSuchElementException;
import java.util.Set; import java.util.Set;
import static io.netty.util.internal.ObjectUtil.checkNotNull;
public class DefaultHttpHeaders extends HttpHeaders { public class DefaultHttpHeaders extends HttpHeaders {
private static final int BUCKET_SIZE = 17; private static final int BUCKET_SIZE = 17;
@ -382,9 +384,7 @@ public class DefaultHttpHeaders extends HttpHeaders {
} }
private static CharSequence toCharSequence(Object value) { private static CharSequence toCharSequence(Object value) {
if (value == null) { checkNotNull(value, "value");
return null;
}
if (value instanceof CharSequence) { if (value instanceof CharSequence) {
return (CharSequence) value; return (CharSequence) value;
} }

View File

@ -55,4 +55,16 @@ public class HttpHeadersTest {
assertThat(HttpHeaders.equalsIgnoreCase("bar", null), is(false)); assertThat(HttpHeaders.equalsIgnoreCase("bar", null), is(false));
assertThat(HttpHeaders.equalsIgnoreCase("FoO", "fOo"), is(true)); assertThat(HttpHeaders.equalsIgnoreCase("FoO", "fOo"), is(true));
} }
@Test(expected = NullPointerException.class)
public void testSetNullHeaderValueValidate() {
HttpHeaders headers = new DefaultHttpHeaders(true);
headers.set("test", (CharSequence) null);
}
@Test(expected = NullPointerException.class)
public void testSetNullHeaderValueNotValidate() {
HttpHeaders headers = new DefaultHttpHeaders(false);
headers.set("test", (CharSequence) null);
}
} }