|
@@ -0,0 +1,67 @@
|
|
|
+package org.springframework.security.integration;
|
|
|
+
|
|
|
+import static org.junit.Assert.assertEquals;
|
|
|
+
|
|
|
+import org.junit.Test;
|
|
|
+import org.junit.runner.RunWith;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.mock.web.MockFilterChain;
|
|
|
+import org.springframework.mock.web.MockHttpServletRequest;
|
|
|
+import org.springframework.mock.web.MockHttpServletResponse;
|
|
|
+import org.springframework.mock.web.MockHttpSession;
|
|
|
+import org.springframework.security.context.HttpSessionContextIntegrationFilter;
|
|
|
+import org.springframework.security.context.SecurityContextHolder;
|
|
|
+import org.springframework.security.providers.UsernamePasswordAuthenticationToken;
|
|
|
+import org.springframework.security.util.AuthorityUtils;
|
|
|
+import org.springframework.security.util.FilterChainProxy;
|
|
|
+import org.springframework.test.context.ContextConfiguration;
|
|
|
+import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
|
|
+
|
|
|
+import javax.servlet.http.HttpSession;
|
|
|
+
|
|
|
+@ContextConfiguration(locations={"/http-path-param-stripping-app-context.xml"})
|
|
|
+@RunWith(SpringJUnit4ClassRunner.class)
|
|
|
+public class HttpPathParameterStrippingTests {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private FilterChainProxy fcp;
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void securedFilterChainCannotBeBypassedByAddingPathParameters() throws Exception {
|
|
|
+ MockHttpServletRequest request = new MockHttpServletRequest();
|
|
|
+ request.setPathInfo("/secured;x=y/admin.html");
|
|
|
+ request.setSession(createAuthenticatedSession("ROLE_USER"));
|
|
|
+ MockHttpServletResponse response = new MockHttpServletResponse();
|
|
|
+ fcp.doFilter(request, response, new MockFilterChain());
|
|
|
+ assertEquals(403, response.getStatus());
|
|
|
+ }
|
|
|
+
|
|
|
+ @Test
|
|
|
+ public void adminFilePatternCannotBeBypassedByAddingPathParameters() throws Exception {
|
|
|
+ MockHttpServletRequest request = new MockHttpServletRequest();
|
|
|
+ request.setServletPath("/secured/admin.html;x=user.html");
|
|
|
+ request.setSession(createAuthenticatedSession("ROLE_USER"));
|
|
|
+ MockHttpServletResponse response = new MockHttpServletResponse();
|
|
|
+ fcp.doFilter(request, response, new MockFilterChain());
|
|
|
+ assertEquals(403, response.getStatus());
|
|
|
+
|
|
|
+ // Try with pathInfo
|
|
|
+ request = new MockHttpServletRequest();
|
|
|
+ request.setServletPath("/secured");
|
|
|
+ request.setPathInfo("/admin.html;x=user.html");
|
|
|
+ request.setSession(createAuthenticatedSession("ROLE_USER"));
|
|
|
+ response = new MockHttpServletResponse();
|
|
|
+ fcp.doFilter(request, response, new MockFilterChain());
|
|
|
+ assertEquals(403, response.getStatus());
|
|
|
+ }
|
|
|
+
|
|
|
+ public HttpSession createAuthenticatedSession(String... roles) {
|
|
|
+ MockHttpSession session = new MockHttpSession();
|
|
|
+ SecurityContextHolder.getContext().setAuthentication(new UsernamePasswordAuthenticationToken("bob", "bobspassword",
|
|
|
+ AuthorityUtils.stringArrayToAuthorityArray(roles)));
|
|
|
+ session.setAttribute(HttpSessionContextIntegrationFilter.SPRING_SECURITY_CONTEXT_KEY, SecurityContextHolder.getContext());
|
|
|
+ SecurityContextHolder.clearContext();
|
|
|
+ return session;
|
|
|
+ }
|
|
|
+
|
|
|
+}
|