Avoid NPE in FilterInvocation
Handle unknown headers in dummy request wrapper. Closes gh-12998
This commit is contained in:
parent
e25117856e
commit
442faccb5f
|
@ -26,6 +26,7 @@ import java.lang.reflect.Proxy;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.Enumeration;
|
import java.util.Enumeration;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
|
@ -257,7 +258,11 @@ public class FilterInvocation {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Enumeration<String> getHeaders(String name) {
|
public Enumeration<String> getHeaders(String name) {
|
||||||
return Collections.enumeration(this.headers.get(name));
|
List<String> headerList = this.headers.get(name);
|
||||||
|
if (headerList == null) {
|
||||||
|
return Collections.emptyEnumeration();
|
||||||
|
}
|
||||||
|
return Collections.enumeration(headerList);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -16,6 +16,9 @@
|
||||||
|
|
||||||
package org.springframework.security.web;
|
package org.springframework.security.web;
|
||||||
|
|
||||||
|
import java.util.Enumeration;
|
||||||
|
import java.util.NoSuchElementException;
|
||||||
|
|
||||||
import javax.servlet.FilterChain;
|
import javax.servlet.FilterChain;
|
||||||
import javax.servlet.http.HttpServletRequest;
|
import javax.servlet.http.HttpServletRequest;
|
||||||
import javax.servlet.http.HttpServletResponse;
|
import javax.servlet.http.HttpServletResponse;
|
||||||
|
@ -142,4 +145,23 @@ public class FilterInvocationTests {
|
||||||
assertThat(filterInvocation.getRequest().getServletContext()).isSameAs(mockServletContext);
|
assertThat(filterInvocation.getRequest().getServletContext()).isSameAs(mockServletContext);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDummyRequestGetHeaders() {
|
||||||
|
DummyRequest request = new DummyRequest();
|
||||||
|
request.addHeader("known", "val");
|
||||||
|
Enumeration<String> headers = request.getHeaders("known");
|
||||||
|
assertThat(headers.hasMoreElements()).isTrue();
|
||||||
|
assertThat(headers.nextElement()).isEqualTo("val");
|
||||||
|
assertThat(headers.hasMoreElements()).isFalse();
|
||||||
|
assertThatExceptionOfType(NoSuchElementException.class).isThrownBy(headers::nextElement);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testDummyRequestGetHeadersNull() {
|
||||||
|
DummyRequest request = new DummyRequest();
|
||||||
|
Enumeration<String> headers = request.getHeaders("unknown");
|
||||||
|
assertThat(headers.hasMoreElements()).isFalse();
|
||||||
|
assertThatExceptionOfType(NoSuchElementException.class).isThrownBy(headers::nextElement);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue