荔枝味的真知棒 2022-08-17 15:10 采纳率: 0%
浏览 16

spring cloud gateway

问题遇到的现象和发生背景

spring cloud gateway 网关,在请求过程中,如果请求方主动断开连接的话,网关不会执行重写response的方法。

问题相关代码,请勿粘贴截图
@Override
    public int getOrder() {
        // -1 is response write filter, must be called before that
        return NettyWriteResponseFilter.WRITE_RESPONSE_FILTER_ORDER - 1;
    }

@Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
//        log.info("order:{}", getOrder());
        GatewayContext gatewayContext = (GatewayContext) exchange.getAttributes().get(GatewayContext.CACHE_GATEWAY_CONTEXT);

        ServerHttpResponse originalResponse = exchange.getResponse();
//        HttpHeaders headers = originalResponse.getHeaders();


        DataBufferFactory bufferFactory = originalResponse.bufferFactory();
        ServerHttpResponseDecorator decoratedResponse = new ServerHttpResponseDecorator(originalResponse) {


            @Override
            public Mono<Void> writeWith(Publisher<? extends DataBuffer> body) {
                if (body instanceof Flux) {
                    Flux<? extends DataBuffer> fluxBody = (Flux<? extends DataBuffer>) body;
                    return super.writeWith(fluxBody.buffer().map(dataBuffer -> {
                        DataBufferFactory dataBufferFactory = new DefaultDataBufferFactory();
                        DataBuffer join = dataBufferFactory.join(dataBuffer);
                        byte[] content = new byte[join.readableByteCount()];
                        join.read(content);
                        //释放掉内存
                        DataBufferUtils.release(join);
                        String responseString = new String(content, StandardCharsets.UTF_8);
                        List<String> strings = exchange.getResponse().getHeaders().get(HttpHeaders.CONTENT_ENCODING);
                        if (!CollectionUtils.isEmpty(strings) && strings.contains("gzip")) {
                            GZIPInputStream gzipInputStream = null;
                            try {
                                gzipInputStream = new GZIPInputStream(new ByteArrayInputStream(content), content.length);
                                StringWriter writer = new StringWriter();
                                IOUtils.copy(gzipInputStream, writer, "UTF-8");
                                responseString = writer.toString();

                            } catch (IOException e) {
                                e.printStackTrace();
                            }
                        }
                         // 此处为实际业务逻辑

                        
                        return bufferFactory.wrap(bytes);
                    }));
                }
                // if body is not a flux. never got there.
                return super.writeWith(body);
            }
        };
        // replace response with decorator
        return chain.filter(exchange.mutate().response(decoratedResponse).build());
    }
运行结果及报错内容

业务逻辑可以正常运行,但是因为请求方主动断开连接之后,不执行writeWith,不能将response重写。

我的解答思路和尝试过的方法

使用链路追踪之后,返现filter前后都是可以正常运行,排除了代码问题。
寻找网关有无其他配置项,没有找到,还在寻找。
打开了网关监控日志,没有发现什么指定的问题。

我想要达到的结果

请求方主动断开连接之后还可以正常进入 writeWith方法。

  • 写回答

1条回答 默认 最新

  • CSDN-Ada助手 CSDN-AI 官方账号 2022-08-18 16:30
    关注
    关于该问题,我找了一篇非常好的博客,你可以看看是否有帮助,链接:Spring Cloud Gateway
    评论

报告相同问题?

问题事件

  • 创建了问题 8月17日

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘