利用转发至Controller处理Filter中抛出的异常

文章讨论了在SpringMVC架构下,如何处理Filter中抛出的异常,因为这些异常不能被全局异常处理器直接捕获。文中提出了一种解决方案,即在Filter中检测到未登录状态时,通过请求转发到一个特定的Controller(ErrorController),在该Controller中抛出异常,从而让全局异常处理器能够捕获并处理这个异常。这种方法主要用于实现对未登录用户的登录检查和错误提示。
摘要由CSDN通过智能技术生成

根据springmvc架构,filter中抛出的异常无法被全局异常处理器捕获,这里利用路由转发,在controller中抛出异常

filter类:

@WebFilter(filterName = "loginCheckFilter", urlPatterns = "/*")
@Slf4j
public class LoginCheckFilter implements Filter {

    //路径匹配器
    public static final AntPathMatcher PATH_MATCHER = new AntPathMatcher();

    @Override
    public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
        HttpServletRequest request = (HttpServletRequest)servletRequest;
        HttpServletResponse response  =(HttpServletResponse)servletResponse;
        //获取URI
        String requestURI = request.getRequestURI();

        //不需要处理的路径
        String[] urls = new String[] {
                "/api/user/login"
        };
        //检测请求是否需要处理
        boolean check = check(urls, requestURI);
        //如果不需要处理
        if(check) {
            log.info("无需处理{}",requestURI);
            filterChain.doFilter(request,response);
            return;
        }
        //判断登录状态,如果登录就放行
        if (request.getSession().getAttribute(USER_LOGIN_STATE) != null) {
            log.info("用户已经登陆:{}",request.getSession().getAttribute(USER_LOGIN_STATE));
            filterChain.doFilter(request,response);
            return;
        } else {
            //未登录抛异常
            request.setAttribute("exception", new BusinessException(ErrorCode.NULL_ERROR, "未登录"));
            request.getRequestDispatcher("/error/login").forward(request, response);
        }
    }

    /**
     * 路径匹配,检查请求是否需要放行
     * @param requestURI
     * @param urls
     * @return
     */
    public boolean check(String[] urls, String requestURI) {
        for(String url: urls) {
            boolean match = PATH_MATCHER.match(url, requestURI);
            if(match) {
                return true;
            }
        }
        return false;
    }
}

转发消息值ErrorController,在其方法内部抛出异常,从而使全局异常处理器捕获

@RestController
@RequestMapping("/error")
public class ErrorController {

    @PostMapping("/login")
    public BaseResponse<Integer> throwException(HttpServletRequest request) throws Exception {
        throw new BusinessException(ErrorCode.NULL_ERROR, "未登录");
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值