SpringBoot整合Beetl後統一處理頁面異常
阿新 • • 發佈:2019-12-31
背景
SpringBoot整合Beetl後如果頁面出現異常會將出現異常之前的頁面輸出到客戶端,但是由於頁面不完整會導致使用者看到的頁面錯亂或者空白,如下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
複製程式碼
在控制檯可以看到
>>11:11:47:該方法未註冊(FUNCTION_NOT_FOUND):err 位於8行 資源:modular/sys/login/login.html
5| <title>Title</title>
6|</head>
7|<body>
8| ${err()}
9|</body>
10|</html>
複製程式碼
我們一般希望當出現異常時返回異常提示頁面而不是不完整的頁面。
設定ErrorHandler
Beetl預設發生頁面異常時不對異常進行丟擲,在檔案中我們可以看到
2.2.3版本以後,新增加org.beetl.ext.web.WebErrorHandler,可以在web開發的時候在頁面輸出提示資訊,在產品模式下在後臺輸出提示資訊(通過配置屬性ESOURCE.autoCheck= true來認為是開發模式),僅僅需要配置如下:
ERROR_HANDLER = org.beetl.ext.web.WebErrorHandler
複製程式碼
所以這裡設定ErrorHandler
,使用Beetl提供的org.beetl.ext.web.WebErrorHandler
BeetlConfiguration beetlConfiguration = new BeetlConfiguration();
beetlConfiguration.setErrorHandler(new WebErrorHandler());
複製程式碼
再次訪問頁面可以看到頁面中顯示了呼叫棧
根據環境做不同處理
在實際應用中,開發環境我們希望看到異常資訊,生產環境希望看到的是統一的異常提示頁面,而不是使用者看不懂的程式碼資訊,在org.beetl.ext.web.WebErrorHandler
中可以看到
//判斷是不是開發者模式,如果不是呼叫父類方法(預設輸出控制檯)
if (!Boolean.valueOf(e.gt.getConf().getProperty("RESOURCE.autoCheck" ))){
super.processExcption(e,writer);
}
複製程式碼
這裡通過配置屬性ESOURCE.autoCheck= true來認為是開發模式,但是通過BeetlConfiguration.setConfigProperties
設定ESOURCE.autoCheck=false
後依然無效(模板不會熱載入,但是這邊依舊當做開發環境),也有可能是我設定不對的原因。
所以通過自定義WebErrorHandler
解決此問題,通過判斷spring.spring.active
去判斷當前環境;也可以丟擲異常到全域性異常統一處理。