SSM 返回靜態頁面HTML Controller 被遞歸調用引起的StackOverflowError
阿新 • • 發佈:2019-03-04
後端 這也 map 靜態頁面 source pro 轉載 請求 nal
三 重現
一 背景
最近在做工程實踐,想實現這麽一個效果:
- 前端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,視圖解析器:
<!-- 配置視圖解析器 --> <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 { @RequestMapping(value = "/search", method = RequestMethod.GET)public String searchHtml() { System.out.println("search html"); return "isearch"; } @RequestMapping(value = "/view", method = RequestMethod.GET) 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 :-)
SSM 返回靜態頁面HTML Controller 被遞歸調用引起的StackOverflowError