上一节我们将项目搭建上了。
这一节我们进行异常处理
在模板资源目录中创建error目录
目录中创建这三个html,文件名开头必须为这些,后面可以稍作更改。(可能可以不为404等开头,我说的可能比较片面,技术在进步嘛。人人皆学习!)
内容分别为
在你以自己喜好创建的包名处右击创建子包controller
在子包下创建类indexController,返回首页的一个控制器
前面要加上一个Controller,代表他是一个控制器
package net.yq.springbootblog.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
@Controller
public class indexController {
@GetMapping("/")//通过get方式请求根路径,就返回index
public String index() {
int i = 3/0;//人为模拟异常情况。不能作为分母,所以会有一些异常。
return "index";
}
}
int i = 3/0; 这个的意思就是模拟异常情况
运行后访问http://127.0.0.1:8080/
会返回之前定义的500那个页面。
因为此时出现了异常,所以Spring Boot会拦截那个异常并且返回500那个页面。
如果注释掉int i = 3/0;
就会正常返回首页。
之前添加了开发工具,不用重启项目在箭头处重新构建一下再去刷新
测试404页面也很简单,在网址后面随便输入些东西,就会返回自定义的404页面。
接下来如何让错误时返回到自定义error页面呢?
此时就自定义一个拦截器
创建子包
handler
在子包中创建一个新的类
ControllerExceptionHandler
加上注解
@ControllerAdvice
//拦截所有标注Controller的控制器。
接下来定义方法
@ExceptionHandler(Exception.class)//标识方法可以做异常处理,表示它拦截的异常只要是Exception都可以由他处理。
public ModelAndView exceptionHandler(HttpServletRequest request,Exception e) throws Exception {
return null;//避免报错
}
HttpServletRequest request
表示在何处访问发生的异常。发生了什么异常就是Exception e
加上@ExceptionHandler()
表示他可以进行异常处理在括弧中加上Exception.class
就代表只要是Exception级别的他都可以拦截。处理。
那我希望能记录异常,那这个时候就获取日志
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
private final Logger logger = LoggerFactory