zuul 拦截器 getWriter() has already been called for this response

1 篇文章 0 订阅

不废话直接上代码。

第一个拦截器:

@Component
public class BaseDataFilter extends ZuulFilter {
    /**
    * filter 共有四种拦截类型
    * FilterConstants.PRE_TYPE  (pre)路由到微服务之前
    * FilterConstants.ROUTE_TYPE  (route)路由到对应微服务
    * FilterConstants.POST_TYPE  (post)路由到对应微服务之后
    * FilterConstants.ERROR  (error)路由到对应微服务后 发生错误
    */
    @Override
    public String filterType() {
        //注意这里哦
        return FilterConstants.PRE_TYPE;
    }

    /**
    * filter执行顺序 从小到大执行
    */
    @Override
    public int filterOrder() {
        return 0;
    }
    
    /**
    * filter规则
    */
    @Override
    public boolean shouldFilter() {
        return true;
    }
    /**
    * 执行活动及任务
    */
    @Override
    public Object run() throws ZuulException {
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletResponse response = currentContext.getResponse();
        response.setContentType("application/json; charset=utf8");
        response.setStatus(20006);
        PrintWriter writer = null;
        try {
            writer = response.getWriter();
            writer.print(JSON.toJSON(new Result(false, 20006, "访问出错!")));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(writer!=null){
                writer.flush();
                writer.close();
            }
        }
        return null;
    }
}

第二个拦截器:

@Component
public class SystemErrorFilter extends ZuulFilter {
    @Override
    public String filterType() {
        //注意这里哦
        return FilterConstants.ERROR_TYPE;
    }

    @Override
    public int filterOrder() {
        return 1;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() throws ZuulException {
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletResponse response = currentContext.getResponse();
        response.setContentType("application/json; charset=utf8");
        response.setStatus(20001);
        PrintWriter writer = null;
        try {
            writer = response.getWriter();
            writer.print(JSON.toJSON(new Result(false, 20001, "获取数据失败,请联系管理员!")));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(writer!=null){
                writer.flush();
                writer.close();
            }
        }
        return null;
    }
}

访问后报错,getWriter() has already been called for this response

原因多次filter导致

解决方式:

我的解决方式是,调用currentContext.setSendZuulResponse(false);防止执行后面其他拦截器。(注意:当前改动的是第一个拦截器哦)

@Component
public class BaseDataFilter extends ZuulFilter {
    @Override
    public String filterType() {
        //注意这里哦
        return FilterConstants.PRE_TYPE;
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() throws ZuulException {
        RequestContext currentContext = RequestContext.getCurrentContext();
        HttpServletResponse response = currentContext.getResponse();
        response.setContentType("application/json; charset=utf8");
        response.setStatus(20006);
        PrintWriter writer = null;
        try {
            //防止后面过滤器继续执行,添加的在这里
            currentContext.setSendZuulResponse(false);
            writer = response.getWriter();
            writer.print(JSON.toJSON(new Result(false, 20006, "访问出错!")));
        } catch (IOException e) {
            e.printStackTrace();
        } finally {
            if(writer!=null){
                writer.flush();
                writer.close();
            }
        }
        return null;
    }
}

请根据自己的实际情况判断该方法是否可行,不要盲目使用当前方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值