1. 程式人生 > 程式設計 >SpringBoot整合Beetl後統一處理頁面異常

SpringBoot整合Beetl後統一處理頁面異常

背景

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去判斷當前環境;也可以丟擲異常到全域性異常統一處理。