您好,登录后才能下订单哦!
这篇文章给大家介绍怎么在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过滤器对全局异常处理进行配置就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。