1. 程式人生 > >SSM 返回靜態頁面HTML Controller 被遞歸調用引起的StackOverflowError

SSM 返回靜態頁面HTML Controller 被遞歸調用引起的StackOverflowError

後端 這也 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