springBoot 在过滤器中如何捕获抛出的异常并自定义返回信息 (Filter doFilter)解决方案

在使用 servlet 过滤器时 发现异常报错 不准确,定义的 全局异常处理 好像失效了,过滤器里报错每次都会返回 状态码 :500 错误信息为 "Internal Server Error" 真正的异常只能输出的控制台,抛出不到前端。

问题:

一般springBoot自带的全局异常捕获机制都是在业务层发生的异常来进行捕获的,因为过滤器的执行顺序是在全局异常机制启动之前执行的,所以一旦过滤器中发生异常,全局异常捕获机制无法使用

以下是解决方案:

在过滤器中try-catch掉需要捕获的异常,返回自定义信息

使用 HttpServletResponse 响应体 直接返回前端错误信息

java 复制代码
  @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {

        HttpServletRequest httpServletRequest = (HttpServletRequest) request;
        HttpServletResponse httpServletResponse = (HttpServletResponse) response;

    
        try {
            //写一些比如 token的异常 这里可以捕获

        }catch (KuaiJingRuntimeException ke){
            try {
                WlUtils.getOutException(httpServletResponse,R.fail(ke.getMessage()));
            } catch (Exception e) {
                throw new RuntimeException(e);
            }
            return;
        }





    }

R.fail() r 就是返回前端的结构体!!!

工具类:

java 复制代码
    public static void getOutException(HttpServletResponse response,R r) throws Exception {
        response.setContentType("application/json;charset=UTF-8");
        PrintWriter out = response.getWriter();
        String jsonObject = JSON.toJSONString(r);
        out.println(jsonObject);
        out.flush();
        out.close();
    }
相关推荐
逸Y 仙X7 分钟前
文章五:Elasticsearch安全通信
java·大数据·安全·elasticsearch·搜索引擎·全文检索·jenkins
quan263117 分钟前
20260529,日常开发-查老数据全量更新闭坑
java·mysql·主从·主从延迟
大大杰哥19 分钟前
Java 日志框架详解:SLF4J + Logback 从入门到实战
java·开发语言·logback
神奇小汤圆23 分钟前
Kafka性能调优:从10万到100万条/秒的实战经验
后端
Dest1ny-安全33 分钟前
2026最新CTF知识库:12大Web漏洞深度文章+1156篇历年大赛WP+50+脚本+Payload速查 +AI/RAG离线在线知识库
java·学习·安全·web安全·servlet
Gopher_HBo33 分钟前
接入层LVS
后端
404号扳手34 分钟前
Java 基础知识(六)
java·后端
前端市界43 分钟前
LotDB Vue 阿里云 ECS 部署实战记录
后端
卷无止境43 分钟前
SimPy 进程通信:让仿真世界里的"对话"变得优雅
后端
ZengLiangYi43 分钟前
多格式文件解析:JSONL / SQLite / Event Stream
前端·javascript·后端