在昨天的文章我跟大家分享了SpringBoot中异常的处理中,我说了一个需要注意的点,就是过滤器中抛出的异常无法被异常处理类捕获,然后这个朋友就问应该如何处理。
其实处理这种问题的处理方式有好几种,那么我就简单分享一下我近期一个项目中的处理方式。
Filter中的异常处理思路
首先我们要明白,在过滤器中我们一般是不会写很长的业务逻辑的,一般都是做一些基础参数或者权限的校验,所以不会出现太过复杂的代码。
既然我们知道代码的长度是可控的,那么在过滤器中我们可以严格的在可能出现异常的地方,用try,catch进行捕获,然后我们通过请求转发的方式转发到对应的Controller上,返回我们需要的json数据;
首先我们先定义一个ErrorController,用来做错误返回。
@RequestMapping(value = "/401")
public Object notLogin(HttpServletRequest request) {
// 取出错误信息
Exception errorMessage = (Exception) request.getAttribute("errorMessage");
String message = errorMessage.getMessage();
System.out.println(message);
return "未登录";
}
接下来在Filter中,模拟一个异常,然后将请求转发到我们自定义的ErrorController中。
@WebFilter(filterName = "baseFilter", urlPatterns = "/*")
public class BaseFilter implements Filter {
@Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("初始化过滤器...");
}
@Override
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain filterChain) throws ServletException, IOException {
HttpServletRequest request = (HttpServletRequest) req;
try {
int i = 0 / 0;
} catch (Exception e) {
// 将错误信息封装在request中
request.setAttribute("errorMessage", e);
// 请求转发
request.getRequestDispatcher("/401").forward(req, resp);
}
filterChain.doFilter(req, resp);
}
}
那么通过上面的简单方式就可以处理过滤器中的异常情况了。
注意:
1、在请求转发的时候,尽量使用request.getRequestDispatcher("/401").forward(req, resp);这种方式,此方式只会在服务器内部转发,客户端地址不会发生任何改变;如果使用response.sendRedirect("/401");请求转发,客户端地址会发生改变,我就是踩了这个坑,调接口Android那边老师有跨域问题,就是因为这个引起的。
2、如果你是第一次在你的SpringBoot工程中使用Filter,那么一定要在启动类上加@ServletComponentScan注解,不然Filter是不会生效的。
好了,今天就到这里。
更多精彩内容请关注微信公众号:一个程序员的成长