在昨天的文章我跟大家分享了SpringBoot中异常的处理中,我说了一个需要注意的点,就是过滤器中抛出的异常无法被异常处理类捕获,然后这个朋友就问应该如何处理。
其实处理这种问题的处理方式有好几种,那么我就简单分享一下我近期一个项目中的处理方式。
首先我们要明白,在过滤器中我们一般是不会写很长的业务逻辑的,一般都是做一些基础参数或者权限的校验,所以不会出现太过复杂的代码。
既然我们知道代码的长度是可控的,那么在过滤器中我们可以严格的在可能出现异常的地方,用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是不会生效的。
好了,今天就到这里。