SpringBoot多種自定義錯誤頁面方式小結(jié)
在項目中為了友好化,對于錯誤頁面,我們常常會使用自定義的頁面。SSM框架組合時代,我們通常通過攔截或者在web.xml中設(shè)置對于錯誤碼的錯誤頁面,然而到了SpringBoot,web.xml消失了,SpringBootServletInitializer初始化servlet代替了web.xml。難道要再把web.xml加回去?這樣雖然可以做到,但并不合理。
下面提供了多種在SpringBoot中實現(xiàn)自定義錯誤頁面的方法。
以前web.xml方式
先來看下在web.xml中配置錯誤頁面的方式:
<error-page> <error-code>404</error-code> <location>/error/404.jsp</location> </error-page>
SpringBoot中實現(xiàn)方式
在SpringBoot后,可以通過如下幾種方式實現(xiàn)自定義錯誤頁面。
1.實現(xiàn)EmbeddedServletContainerCustomizer的bean
適合內(nèi)嵌服務(wù)器,先在controller中定義我們的錯誤頁面Mapping,通過在配置類中實現(xiàn)EmbeddedServletContainerCustomizer的bean,加入對應(yīng)狀態(tài)碼的錯誤頁面。注意這種方式在打成war后,供外部tomcat使用時,將會失效。
定義錯誤頁面:
@RequestMapping(value = "/error/[code]") public String error(@PathVariable int code, Model model) { String pager = "/content/error-pager"; switch (code) { case 404: model.addAttribute("code", 404); pager = "/content/error-pager"; break; case 500: model.addAttribute("code", 500); pager = "/content/error-pager"; break; } return pager; }
在配置類中加入EmbeddedServletContainerCustomizer:
/** * 配置默認錯誤頁面(僅用于內(nèi)嵌tomcat啟動時) * 使用這種方式,在打包為war后不起作用 * * @return */ @Bean public EmbeddedServletContainerCustomizer containerCustomizer() { return container -> { ErrorPage error404Page = new ErrorPage(HttpStatus.NOT_FOUND, "/error/404"); ErrorPage error500Page = new ErrorPage(HttpStatus.INTERNAL_SERVER_ERROR, "/error/500"); container.addErrorPages(error404Page, error500Page); };
2.通過攔截器方式
適合內(nèi)嵌Tomcat或者war方式。
/** * @author hgs * @version ErrorPageInterceptor.java, v 0.1 2018/03/04 20:52 hgs Exp $ * <p> * 錯誤頁面攔截器 * 替代EmbeddedServletContainerCustomizer在war中不起作用的方法 */ @Component public class ErrorPageInterceptor extends HandlerInterceptorAdapter { private List<Integer> errorCodeList = Arrays.asList(404, 403, 500, 501); @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if (errorCodeList.contains(response.getStatus())) { response.sendRedirect("/error/" + response.getStatus()); return false; } return super.preHandle(request, response, handler); } }
在配置類中添加攔截
@Configuration public class WebMvcConfig extends WebMvcConfigurerAdapter { @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(errorPageInterceptor);//.addPathPatterns("/action/**", "/mine/**");默認所有 super.addInterceptors(registry); } }
3.自定義靜態(tài)error頁面方法
在resource/templates下添加error.html頁面,springBoot會自動找到該頁面作為錯誤頁面,適合內(nèi)嵌Tomcat或者war方式。
SpringBoot錯誤視圖提供了以下錯誤屬性:
timestamp
:錯誤發(fā)生時間;status
:HTTP狀態(tài)嗎;error
:錯誤原因;exception
:異常的類名;message
:異常消息(如果這個錯誤是由異常引起的);errors
:BindingResult異常里的各種錯誤(如果這個錯誤是由異常引起的);trace
:異常跟蹤信息(如果這個錯誤是由異常引起的);path
:錯誤發(fā)生時請求的URL路徑。
SpringBoot使用的前端框架模板不同,頁面的名稱也有所不同:
- 實現(xiàn)Spring的View接口的Bean,其ID需要設(shè)置為error(由Spring的BeanNameViewResolver所解析);
- 如果配置了Thymeleaf,則需命名為error.html的Thymeleaf模板;
- 如果配置了FreeMarker,則需命名為error.ftl的FreeMarker模板;
- 如果配置了Velocity,則需命名為error.vm的Velocity模板;
- 如果是用JSP視圖,則需命名為error.jsp的JSP模板。
Thymeleaf實例:
<!DOCTYPE html> <html lang="en" xmlns:th="http://www.thymeleaf.org"> <head> <title th:text="${title}"></title> </head> <body class="layout"> <div class="wrap"> <!-- S top --> <div th:include="/header/module-header::module-header"></div> <!-- S 內(nèi)容 --> <div class="panel-l container clearfix"> <div class="error"> <p class="title"><span class="code" th:text="${status}"></span>非常抱歉,沒有找到您要查看的頁面</p> <a href="/" rel="external nofollow" class="btn-back common-button">返回首頁 <img class="logo-back" src="/img/back.png"> </a> <div class="common-hint-word"> <div th:text="${#dates.format(timestamp,'yyyy-MM-dd HH:mm:ss')}"></div> <div th:text="${messages}"></div> <div th:text="${error}"></div> </div> </div> </div> </div> </div> </body> </html>
對于外部Tomcat第三中方案是比較推薦的一種實現(xiàn)方式,但不夠靈活,我們不好定義自己的屬性,如果想對其做相應(yīng)修改,可以參見源碼BasicErrorController,通過繼承AbstractErrorController,并重寫errorHtml方法,達到自己想要的效果。在內(nèi)嵌Tomcat時,第一種推薦使用,更具靈活性。
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
spring boot整合mybatis+mybatis-plus的示例代碼
這篇文章主要介紹了spring boot整合mybatis+mybatis-plus的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01總結(jié)Java常用的時間相關(guān)轉(zhuǎn)化
今天給大家?guī)淼氖顷P(guān)于Java的相關(guān)知識,文章圍繞著Java常用的時間相關(guān)轉(zhuǎn)化展開,文中有非常詳細的介紹及代碼示例,需要的朋友可以參考下2021-06-06java+jdbc+mysql+socket搭建局域網(wǎng)聊天室
這篇文章主要為大家詳細介紹了java+jdbc+mysql+socket搭建局域網(wǎng)聊天室,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01IDEA2019.2.2配置Maven3.6.2打開出現(xiàn)Unable to import Maven project
這篇文章主要介紹了IDEA2019.2.2配置Maven3.6.2打開出現(xiàn)Unable to import Maven project,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12java開發(fā)工作中對InheritableThreadLocal使用思考
這篇文章主要為大家介紹了java開發(fā)工作中對InheritableThreadLocal使用思考詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11