SSM 返回静态页面HTML Controller 被递归调用引起的StackOverflowError
一 背景
最近在做工程實踐,想實現這么一個效果:
- 前端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請求的方法被遞歸調用了;
- Controller中searchHtml()方法返回的字符串"search"(對應search.html文件)經過視圖解析器處理(請求轉發)后剛好又變成了url:/idevtools/search,所以searchHtml()又一次被調用;
三 重現
1.在webapp/目錄下存2個html文件:isearch.html,view.html,目錄如下:
2.配置spring-mvc.xml,視圖解析器:
<!-- 配置視圖解析器 --> <bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver"><property name="prefix" value="/"/><property name="suffix" value=".html"/> </bean>3.編寫HtmlController,如下:
/*** 靜態頁面請求處理Controller* @author southday* @date 2019/3/4*/ @Controller public class HtmlController {@GetMapping("/search")public String searchHtml() {System.out.println("search html");return "isearch";}@GetMapping("/view")public String 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
總結
以上是生活随笔為你收集整理的SSM 返回静态页面HTML Controller 被递归调用引起的StackOverflowError的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 求最小公倍数的最简模板
- 下一篇: 前端项目编程规范