mirror of
https://github.com/spring-projects/spring-security.git
synced 2025-05-31 09:12:14 +00:00
SEC-1714: RegexRequestMatcher should prepend question mark to query string.
This commit is contained in:
parent
49dd928faa
commit
ef72dd1986
@ -55,7 +55,7 @@ public final class RegexRequestMatcher implements RequestMatcher {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Performs the match of the request URL ({@code servletPath + pathInfo + queryString}) against
|
* Performs the match of the request URL ({@code servletPath + pathInfo + queryString}) against
|
||||||
* the compiled pattern.
|
* the compiled pattern. If the query string is present, a question mark will be prepended.
|
||||||
*
|
*
|
||||||
* @param request the request to match
|
* @param request the request to match
|
||||||
* @return true if the pattern matches the URL, false otherwise.
|
* @return true if the pattern matches the URL, false otherwise.
|
||||||
@ -77,7 +77,7 @@ public final class RegexRequestMatcher implements RequestMatcher {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (query != null) {
|
if (query != null) {
|
||||||
sb.append(query);
|
sb.append('?').append(query);
|
||||||
}
|
}
|
||||||
url = sb.toString();
|
url = sb.toString();
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,43 @@
|
|||||||
|
package org.springframework.security.web.util;
|
||||||
|
|
||||||
|
import static org.junit.Assert.*;
|
||||||
|
|
||||||
|
import org.junit.*;
|
||||||
|
import org.springframework.mock.web.MockHttpServletRequest;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Luke Taylor
|
||||||
|
*/
|
||||||
|
public class RegexRequestMatcherTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void doesntMatchIfHttpMethodIsDifferent() throws Exception {
|
||||||
|
RegexRequestMatcher matcher = new RegexRequestMatcher(".*", "GET");
|
||||||
|
|
||||||
|
MockHttpServletRequest request = new MockHttpServletRequest("POST", "/anything");
|
||||||
|
|
||||||
|
assertFalse(matcher.matches(request));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void matchesIfHttpMethodAndPathMatch() throws Exception {
|
||||||
|
RegexRequestMatcher matcher = new RegexRequestMatcher(".*", "GET");
|
||||||
|
|
||||||
|
MockHttpServletRequest request = new MockHttpServletRequest("GET", "/anything");
|
||||||
|
request.setServletPath("/anything");
|
||||||
|
|
||||||
|
assertTrue(matcher.matches(request));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void queryStringIsMatcherCorrectly() throws Exception {
|
||||||
|
RegexRequestMatcher matcher = new RegexRequestMatcher(".*\\?x=y", "GET");
|
||||||
|
|
||||||
|
MockHttpServletRequest request = new MockHttpServletRequest("GET", "/any/path?x=y");
|
||||||
|
request.setServletPath("/any");
|
||||||
|
request.setPathInfo("/path");
|
||||||
|
request.setQueryString("x=y");
|
||||||
|
|
||||||
|
assertTrue(matcher.matches(request));
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user