一 背景
最近在做工程实践,想实现这么一个效果:
前端url请求地址:localhost:8080/idevtools/search
后端返回一个静态页面HTML:search.html
按照网上说的,进行了一些配置,然后运行项目,出现了错误:javax.servlet.ServletException: org.springframework.web.util.NestedServletException: Request processing failed; nested exception is java.lang.StackOverflowError;
二 原因
去网上各种查阅资料,都没找到与该问题相关的文章(这也是我发博客的原因),可能是遇到这类问题的人只有少部分。事实上,确实也只有“机缘巧合”的人会遇到这个问题。
controller中处理/idevtools/search请求的方法被递归调用了;
而导致其被递归调用的原因竟然是:返回的html文件名(search.html)与url请求地址中的search相同;
三 重现
1.在webapp/目录下存2个html文件:isearch.html,view.html,目录如下:
2.配置spring-mvc.xml,视图解析器:
3.编写HtmlController,如下:
/*** 静态页面请求处理Controller
*@authorsouthday
* @date 2019/3/4*/@Controllerpublic classHtmlController {
@RequestMapping(value= "/search", method =RequestMethod.GET)publicString searchHtml() {
System.out.println("search html");return "isearch";
}
@RequestMapping(value= "/view", method =RequestMethod.GET)publicString viewHtml() {
System.out.println("view html");return "view";
}
}
注意看这两个请求的处理:
/search,返回的是isearch,对应的是isearch.html
/view,返回的是view,对应的是view.html
当你运行项目,发送请求时,只有/search可以成功返回html页面,/view则会报异常(StackOverflowError)。具体原因我没去深入了解,但觉得是:
视图解析器中根据Controller返回的字符串“view”,优先匹配了请求/idevtools/view,所以HtmlController中的viewHtml()方法会被递归调用,导致StackOverflowError;
而返回"isearch"时,没有匹配到相应的请求,进而匹配了静态页面"isearch.html",因此能正常返回html页面;
转载请说明出处!have a good time :-)
原文:https://www.cnblogs.com/southday/p/10472727.html