java 过滤器异常处理_Spring下Filter过滤器配置全局异常处理的详细步骤

Spring下Filter过滤器配置全局异常处理

Filter中出现的异常,spring的全局异常处理器是无法捕获的,所以filter拦截器中出现的异常会直接的抛向浏览器,在浏览器中显示500错误。

而我当前的项目中,是在Filter中判断用户是否有携带Token访问,如果没有,则抛出异常,让其做登录操作。而且异常信息要处理成json格式返回给前端。这就很尴尬了。

好了废话说多了,上解决方案:

结局方案:

Filter拦截器中直接抛出异常信息

@Component

public class AdminAuthentiationFilter extends OncePerRequestFilter {

private final String DEFAULTE_URI = "/api/admin/login";

@Override

protected void doFilterInternal(HttpServletRequest req, HttpServletResponse resp, FilterChain filterChain) throws ServletException, IOException {

String admin_token = req.getHeader("admin_token");

if(StrUtil.isBlank(admin_token) && !req.getRequestURI().equals(DEFAULTE_URI)){

//在拦截器中直接抛出一个异常

throw new LoginException("用户未登录,请先登录!");

}

filterChain.doFilter(req,resp);

}

}

第一步:在web.xml中配置错误页,用于捕获500状态

myFilter

com.fenkuan.support.filters.AdminAuthentiationFilter

myFilter

/*

500

/500

第二步:编写一个FilterException自定义异常类

public class FilterException extends RuntimeException{

private String data;

public FilterException(String message) {

super(message);

}

public FilterException(String message, String data) {

super(message, data);

this.data = data;

}

public String getData() {

return data;

}

}

第三步:编写一个用于处理500错误的controller

@RestController

public class FilterErrorController {

@RequestMapping("/500")

public void filterError(HttpServletRequest req){

//获取servlet请求中的异常属性。该属性下存储了确切的错误信息。

Throwable t = (Throwable) req.getAttribute("javax.servlet.error.exception");

//创建一个filterException抛出,该异常会被全局异常处理类捕获,并处理。

throw new FilterException(t.getMessage());

}

}

第四步:编写一个捕获全局异常的异常处理类

//全局异常处理类

@RestControllerAdvice

public class ControllerExceptionHandler{

@ExceptionHandler(FilterException.class)

@ResponseStatus(HttpStatus.BAD_REQUEST)

public BadException> filterException(FilterException e){

BadException objectBadException = handleExceptionObject(e);

objectBadException.setStatus(HttpStatus.BAD_REQUEST.value());

objectBadException.setMessage(e.getMessage());

return objectBadException;

}

@ExceptionHandler(Exception.class)

@ResponseStatus(HttpStatus.INTERNAL_SERVER_ERROR)

public BadException> responseException(Exception e){

//异常兜底处理

BadException> objectBadException = handleExceptionObject(e);

objectBadException.setStatus(HttpStatus.INTERNAL_SERVER_ERROR.value());

objectBadException.setMessage(HttpStatus.INTERNAL_SERVER_ERROR.getReasonPhrase());

return objectBadException;

}

// Throwable是Exception的父类,所以可以使用该类型来接受项目中抛出的所有异常,包括Exception即其子类。

private BadException handleExceptionObject(Throwable throwable){

BadException bad = new BadException<>();

bad.setMessage(throwable.getMessage());

return bad;

}

}

BadException类,用于封装要返会给前端的异常信息(这里使用了Lombok工具)

import lombok.Data;

@Data

public class BadException {

private Integer status;

private String message;

private Object data;

private Object devData;

}

结果:

fac1863ecfae259d6b44f0ec71488835.png

到此这篇关于Spring下Filter过滤器配置全局异常处理的详细步骤的文章就介绍到这了,更多相关Spring全局异常处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值