SPR-6906 - Combination of ControllerClassNameHandlerMapping and @RequestMappings with file extensions results in exception
This commit is contained in:
parent
8fe5151f84
commit
a0c41a0e03
|
|
@ -629,35 +629,15 @@ public class AnnotationMethodHandlerAdapter extends WebContentGenerator
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
private void extractHandlerMethodUriTemplates(String mappedPath,
|
private void extractHandlerMethodUriTemplates(String mappedPattern,
|
||||||
String lookupPath,
|
String lookupPath,
|
||||||
HttpServletRequest request) {
|
HttpServletRequest request) {
|
||||||
Map<String, String> variables = null;
|
|
||||||
boolean hasSuffix = (mappedPath.indexOf('.') != -1);
|
Map<String, String> variables =
|
||||||
if (!hasSuffix && pathMatcher.match(mappedPath + ".*", lookupPath)) {
|
(Map<String, String>) request.getAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE);
|
||||||
String realPath = mappedPath + ".*";
|
|
||||||
if (pathMatcher.match(realPath, lookupPath)) {
|
if (CollectionUtils.isEmpty(variables) && pathMatcher.match(mappedPattern, lookupPath)) {
|
||||||
variables = pathMatcher.extractUriTemplateVariables(realPath, lookupPath);
|
variables = pathMatcher.extractUriTemplateVariables(mappedPattern, lookupPath);
|
||||||
}
|
|
||||||
}
|
|
||||||
if (variables == null && !mappedPath.startsWith("/")) {
|
|
||||||
String realPath = "/**/" + mappedPath;
|
|
||||||
if (pathMatcher.match(realPath, lookupPath)) {
|
|
||||||
variables = pathMatcher.extractUriTemplateVariables(realPath, lookupPath);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
realPath = realPath + ".*";
|
|
||||||
if (pathMatcher.match(realPath, lookupPath)) {
|
|
||||||
variables = pathMatcher.extractUriTemplateVariables(realPath, lookupPath);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!CollectionUtils.isEmpty(variables)) {
|
|
||||||
Map<String, String> typeVariables =
|
|
||||||
(Map<String, String>) request.getAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE);
|
|
||||||
if (typeVariables != null) {
|
|
||||||
variables.putAll(typeVariables);
|
|
||||||
}
|
|
||||||
request.setAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE, variables);
|
request.setAttribute(HandlerMapping.URI_TEMPLATE_VARIABLES_ATTRIBUTE, variables);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,40 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2002-2010 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.web.servlet.mvc.annotation;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.Writer;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.web.bind.annotation.PathVariable;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
|
|
||||||
|
/** @author Arjen Poutsma */
|
||||||
|
@Controller
|
||||||
|
public class FooController {
|
||||||
|
|
||||||
|
@RequestMapping(value = "{id}", method = RequestMethod.GET)
|
||||||
|
public void plain(Writer writer, @PathVariable("id") String id) throws IOException {
|
||||||
|
writer.write("plain-" + id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@RequestMapping(value = "{id}.pdf", method = RequestMethod.GET)
|
||||||
|
public void pdf(Writer writer, @PathVariable("id") String id) throws IOException {
|
||||||
|
writer.write("pdf-" + id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
/*
|
/*
|
||||||
* Copyright 2002-2009 the original author or authors.
|
* Copyright 2002-2010 the original author or authors.
|
||||||
*
|
*
|
||||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
* you may not use this file except in compliance with the License.
|
* you may not use this file except in compliance with the License.
|
||||||
|
|
@ -41,6 +41,7 @@ import org.springframework.web.bind.annotation.RequestMethod;
|
||||||
import org.springframework.web.context.WebApplicationContext;
|
import org.springframework.web.context.WebApplicationContext;
|
||||||
import org.springframework.web.context.support.GenericWebApplicationContext;
|
import org.springframework.web.context.support.GenericWebApplicationContext;
|
||||||
import org.springframework.web.servlet.DispatcherServlet;
|
import org.springframework.web.servlet.DispatcherServlet;
|
||||||
|
import org.springframework.web.servlet.mvc.support.ControllerClassNameHandlerMapping;
|
||||||
|
|
||||||
/** @author Arjen Poutsma */
|
/** @author Arjen Poutsma */
|
||||||
public class UriTemplateServletAnnotationControllerTests {
|
public class UriTemplateServletAnnotationControllerTests {
|
||||||
|
|
@ -337,7 +338,37 @@ public class UriTemplateServletAnnotationControllerTests {
|
||||||
response = new MockHttpServletResponse();
|
response = new MockHttpServletResponse();
|
||||||
servlet.service(request, response);
|
servlet.service(request, response);
|
||||||
assertEquals("bar-bar", response.getContentAsString());
|
assertEquals("bar-bar", response.getContentAsString());
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* See SPR-6906
|
||||||
|
*/
|
||||||
|
@Test
|
||||||
|
public void controllerClassName() throws Exception {
|
||||||
|
servlet = new DispatcherServlet() {
|
||||||
|
@Override
|
||||||
|
protected WebApplicationContext createWebApplicationContext(WebApplicationContext parent)
|
||||||
|
throws BeansException {
|
||||||
|
GenericWebApplicationContext wac = new GenericWebApplicationContext();
|
||||||
|
wac.registerBeanDefinition("controller", new RootBeanDefinition(FooController.class));
|
||||||
|
RootBeanDefinition mapping = new RootBeanDefinition(ControllerClassNameHandlerMapping.class);
|
||||||
|
mapping.getPropertyValues().add("excludedPackages", null);
|
||||||
|
wac.registerBeanDefinition("handlerMapping", mapping);
|
||||||
|
wac.refresh();
|
||||||
|
return wac;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
servlet.init(new MockServletConfig());
|
||||||
|
|
||||||
|
MockHttpServletRequest request = new MockHttpServletRequest("GET", "/foo/bar");
|
||||||
|
MockHttpServletResponse response = new MockHttpServletResponse();
|
||||||
|
servlet.service(request, response);
|
||||||
|
assertEquals("plain-bar", response.getContentAsString());
|
||||||
|
|
||||||
|
request = new MockHttpServletRequest("GET", "/foo/bar.pdf");
|
||||||
|
response = new MockHttpServletResponse();
|
||||||
|
servlet.service(request, response);
|
||||||
|
assertEquals("pdf-bar", response.getContentAsString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -590,5 +621,4 @@ public class UriTemplateServletAnnotationControllerTests {
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue