我目前正在处理一个现有项目(java 版本:1.7.0,使用 Spring MVC 框架版本:3.1.4),我们只PathVariable
在特定控制器类的一个 URI 中找到了这个问题,如果你们中的任何人都已经遇到过这个错误,你们是如何修复/解决它的?谢谢!
代码(java控制器类的提取部分):
@RequestMapping(value = "/site/apps/{question}.json", method = RequestMethod.GET)
public @ResponseBody ServiceResponse moreUsers(
@PathVariable("question") final Question question,
@RequestParam(value = "sort", required = false) final String sort,
final HttpServletRequest request, final Model model)
我们的 tomcat 日志(catalina.out 文件)的错误输出:
ERROR Error executing request: /site/apps/52440.json
org.springframework.web.bind.annotation.support.HandlerMethodInvocationException: Failed to invoke handler method [public com.project.infrastructure.service.ServiceResponse com.project.plugins.controllers.SiteAppController.moreUsers(com.project.models.node.Question,java.lang.String,javax.servlet.http.HttpServletRequest,org.springframework.ui.Model)]; nested exception is java.lang.IllegalStateException: **Could not find @PathVariable [question] in @RequestMapping**
我们已经研究过的内容:
- 根据规范文档(mvc-ann-requestmapping-uri-templates)遵循PathVariable 注释的春季约定,
- 在 java 项目中没有找到其他类似的路径,可能会在 (/site/apps/{question-id}) 内有冲突匹配
- 根据mappedPattern值,我们还记录了映射并且看起来不错(位于此处:https ://github.com/spring-projects/spring-framework/blob/master/spring-webmvc/src/main/java/ org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerAdapter.java#L755-L764)
- 调用resolvePathVariable spring 方法时会发生有趣的事情,因为“URI 模板变量映射”值为空(https://github.com/spring-projects/spring-framework/blob/master/spring-webmvc/src/main/ java/org/springframework/web/servlet/mvc/annotation/AnnotationMethodHandlerAdapter.java#L853-L854不知道为什么!