SpringBoot集成Beetl后統(tǒng)一處理頁面異常的方法
背景
SpringBoot集成Beetl后如果頁面出現(xiàn)異常會將出現(xiàn)異常之前的頁面輸出到客戶端,但是由于頁面不完整會導(dǎo)致用戶看到的頁面錯亂或者空白,如下
<!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>
我們一般希望當(dāng)出現(xiàn)異常時返回異常提示頁面而不是不完整的頁面。
設(shè)置ErrorHandler
Beetl默認(rèn)發(fā)生頁面異常時不對異常進(jìn)行拋出,在文檔中我們可以看到
2.2.3版本以后,新增加org.beetl.ext.web.WebErrorHandler,可以在web開發(fā)的時候在頁面輸出提示信息,在產(chǎn)品模式下在后臺輸出提示信息(通過配置屬性ESOURCE.autoCheck= true來認(rèn)為是開發(fā)模式),僅僅需要配置如下:
ERROR_HANDLER = org.beetl.ext.web.WebErrorHandler
所以這里設(shè)置ErrorHandler,使用Beetl提供的org.beetl.ext.web.WebErrorHandler
BeetlConfiguration beetlConfiguration = new BeetlConfiguration(); beetlConfiguration.setErrorHandler(new WebErrorHandler());
再次訪問頁面可以看到頁面中顯示了調(diào)用棧

根據(jù)環(huán)境做不同處理
在實際應(yīng)用中,開發(fā)環(huán)境我們希望看到異常信息,生產(chǎn)環(huán)境希望看到的是統(tǒng)一的異常提示頁面,而不是用戶看不懂的代碼信息,在org.beetl.ext.web.WebErrorHandler中可以看到
//判斷是不是開發(fā)者模式,如果不是調(diào)用父類方法(默認(rèn)輸出控制臺)
if (!Boolean.valueOf(e.gt.getConf().getProperty("RESOURCE.autoCheck"))){
super.processExcption(e, writer);
}
這里通過配置屬性ESOURCE.autoCheck= true來認(rèn)為是開發(fā)模式,但是通過BeetlConfiguration.setConfigProperties設(shè)置ESOURCE.autoCheck=false后依然無效(模板不會熱加載,但是這邊依舊當(dāng)做開發(fā)環(huán)境),也有可能是我設(shè)置不對的原因。
所以通過自定義WebErrorHandler解決此問題,通過判斷spring.spring.active去判斷當(dāng)前環(huán)境;也可以拋出異常到全局異常統(tǒng)一處理。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
淺談Java內(nèi)存模型之happens-before
于存在線程本地內(nèi)存和主內(nèi)存的原因,再加上重排序,會導(dǎo)致多線程環(huán)境下存在可見性的問題。那么我們正確使用同步、鎖的情況下,線程A修改了變量a何時對線程B可見?下面小編來簡單介紹下2019-05-05
java基于servlet使用組件smartUpload實現(xiàn)文件上傳
這篇文章主要介紹了java基于servlet使用組件smartUpload實現(xiàn)文件上傳,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-10-10
Alibaba?Nacos配置中心動態(tài)感知原理示例解析
這篇文章主要介紹了Alibaba?Nacos配置中心動態(tài)感知原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
如何利用Java輸出鏈表中倒數(shù)第k個結(jié)點
這篇文章主要給大家介紹了關(guān)于如何利用Java輸出鏈表中倒數(shù)第k個結(jié)點的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用java具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2021-12-12

