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状态
<!-- 注册过滤器--> <filter> <filter-name>myFilter</filter-name> <filter-class>com.fenkuan.support.filters.AdminAuthentiationFilter</filter-class> </filter> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <!--捕获500错误状态--> <error-page> <error-code>500</error-code> <location>/500</location> </error-page>
第二步:编写一个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<Object> 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 <T> BadException<T> handleExceptionObject(Throwable throwable){
BadException<T> bad = new BadException<>();
bad.setMessage(throwable.getMessage());
return bad;
}
}
BadException类,用于封装要返会给前端的异常信息(这里使用了Lombok工具)
import lombok.Data;
@Data
public class BadException<T> {
private Integer status;
private String message;
private Object data;
private Object devData;
}
结果:

到此这篇关于Spring下Filter过滤器配置全局异常处理的详细步骤的文章就介绍到这了,更多相关Spring全局异常处理内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Java中ArrayList和LinkedList之间的区别_动力节点Java学院整理
这篇文章主要为大家详细介绍了Java中ArrayList和LinkedList之间的区别,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-05-05
Java NIO Selector用法详解【含多人聊天室实例】
这篇文章主要介绍了Java NIO Selector用法,结合实例形式分析了Java NIO Selector基本功能、原理与使用方法,并结合了多人聊天室实例加以详细说明,需要的朋友可以参考下2019-11-11
一文详解Java17中LinkedList类的用法和应用场景
LinkedList 是 Java 集合框架中基于双向链表实现的类,实现了 List 和 Deque 接口,本文将为大家介绍一下它在Java 17 中如何更高效的使用吧2025-03-03


最新评论