SpringBoot 利用thymeleaf自定義錯(cuò)誤頁面
導(dǎo)入thymeleaf
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId></dependency>
自定義異常類
建立監(jiān)聽異常類
MyException.class
package com.example.demo.domain;public class MyException extends RuntimeException { private int code; private String msg; public MyException(int code, String msg) { this.code = code; this.msg = msg; } public int getCode() { return code; } public void setCode(int code) { this.code = code; } public String getMsg() { return msg; } public void setMsg(String msg) { this.msg = msg; }}
CustomExtHandle 監(jiān)測異常
package com.example.demo.domain;import org.slf4j.LoggerFactory;import org.springframework.web.bind.annotation.ExceptionHandler;import org.springframework.web.bind.annotation.RestControllerAdvice;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import java.util.HashMap;import java.util.Map;import java.util.logging.Logger;@RestControllerAdvicepublic class CustomExtHandle { // 捕獲全局異常 @ExceptionHandler(value = Exception.class) Object handleException(Exception e, HttpServletRequest request) { Map<String, Object> map = new HashMap<>(); map.put('code', 100); map.put('msg', e.getMessage()); map.put('url', request.getRequestURL()); return map; } // 如果是Myexception類 @ExceptionHandler(value = MyException.class) Object handleMyException(MyException e, HttpServletRequest request) { ModelAndView modelAndView = new ModelAndView(); modelAndView.setViewName('error.html'); // 指定錯(cuò)誤跳轉(zhuǎn)頁面 需要在templates里面新建 一個(gè)error.html modelAndView.addObject('msg', e.getMsg()); modelAndView.addObject('code', e.getCode()); modelAndView.addObject('url', request.getRequestURL()); return modelAndView;// 當(dāng)然這里也可以返回json數(shù)據(jù) 前后臺(tái)分離的話直接返回一個(gè)json即可 }}
template/error.html
<!DOCTYPE html><html lang='en'><head> <meta charset='UTF-8'> <title>Title</title></head><body><h1>出異常了</h1><span>錯(cuò)誤信息:</span><h1 th:text='${msg}'></h1> // 獲取變量<span>錯(cuò)誤狀態(tài)碼:</span><h1 th:text='$[code]'></h1><span>失敗API地址:</span><h1 th:text='${url}'></h1></body></html>
使用
@RequestMapping('/user_info') public Map<String, String> testMap() { throw new MyException(500, '手動(dòng)拋出'); }
效果
以上就是SpringBoot 利用thymeleaf自定義錯(cuò)誤頁面的詳細(xì)內(nèi)容,更多關(guān)于SpringBoot 自定義錯(cuò)誤頁面的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. CSS百分比padding制作圖片自適應(yīng)布局2. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)3. CSS清除浮動(dòng)方法匯總4. React優(yōu)雅的封裝SvgIcon組件示例5. 不要在HTML中濫用div6. HTTP協(xié)議常用的請求頭和響應(yīng)頭響應(yīng)詳解說明(學(xué)習(xí))7. TypeScript實(shí)現(xiàn)十大排序算法之歸并排序示例詳解8. Electron調(diào)用外接攝像頭并拍照上傳實(shí)現(xiàn)詳解9. HTML DOM setInterval和clearInterval方法案例詳解10. vue前端RSA加密java后端解密的方法實(shí)現(xiàn)
