【BUG】ServerHttpResponseDecorator失效

1.BUG描述

  1. BUG描述

在Spring Cloud Gateway使用编码的方式实现一个全局拦截器,在全局拦截器中想要打印响应日志。

于是自己装饰了一个具有打印日志功能的ServerHttpResponseDecorator,但是在转发后的服务返回响应的时候,ServerHttpResponseDecorator的writeWith却并没有执行

@Component
@Slf4j
public class CustomGlobaFilter implements GlobalFilter, Ordered {

    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        //响应日志
        return handleResponse(exchange, chain);
    }

    public Mono<Void> handleResponse(ServerWebExchange exchange, GatewayFilterChain chain) {
        try {
            ServerHttpResponse originalResponse = exchange.getResponse();
            // 缓存数据的工厂
            DataBufferFactory bufferFactory = originalResponse.bufferFactory();
            // 拿到响应码
            HttpStatus statusCode = originalResponse.getStatusCode();
            if (statusCode == HttpStatus.OK) {
                // 装饰,增强能力
                ServerHttpResponseDecorator decoratedResponse = new ServerHttpResponseDecorator(originalResponse) {
                    // 等调用完转发的接口后才会执行
                    @Override
                    public Mono<Void>  writeWith(Publisher<? extends DataBuffer> body) {
                        log.info("body instanceof Flux: {}", (body instanceof Flux));
                        if (body instanceof Flux) {
                            Flux<? extends DataBuffer> fluxBody = Flux.from(body);
                            // 往返回值里写数据
                            // 拼接字符串
                            return super.writeWith(
                                    fluxBody.map(dataBuffer -> {
                                        byte[] content = new byte[dataBuffer.readableByteCount()];
                                        dataBuffer.read(content);
                                        //释放掉内存
                                        DataBufferUtils.release(dataBuffer);
                                        // 构建日志
                                        StringBuilder sb2 = new StringBuilder(200);
                                        List<Object> rspArgs = new ArrayList<>();
                                        rspArgs.add(originalResponse.getStatusCode());
                                        //data
                                        String data = new String(content, StandardCharsets.UTF_8); 
                                        sb2.append(data);
                                        // 打印日志
                                        log.info("响应结果:" + data);
                                        return bufferFactory.wrap(content);
                                    }));
                        } else {
                            // 8. 调用失败,返回一个规范的错误码
                            log.error("<--- {} 响应code异常", getStatusCode());
                        }
                        return super.writeWith(body);
                    }
                };
                // 设置 response 对象为装饰过的
                return chain.filter(exchange.mutate().response(decoratedResponse).build());
            }
            // 降级处理返回数据
            return chain.filter(exchange); 
        } catch (Exception e) {
            log.error("网关处理响应异常" + e);
            return chain.filter(exchange);
        }
    }

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

2.BUG解决

将这种写法

@Slf4j
@Component
@Order(-2) <--------------将这个
public class CustomGlobalFilter implements GlobalFilter , Ordered {
........省略
}

改为这种方式

    @Override
    public int getOrder() {
        return -2;
    }

3.BUG分析

查阅官网文档

  1. 官网文档案例采用的是实现接口的方式
    @Override
    public int getOrder() {
        return -2;
    }
  1. 查阅资料之后没有找到详细的解答,还是遵循官方的规范吧,时间有限,不纠结,意义不大。
  • 4
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: irptrace是一种用于跟踪TCP/IP网络数据包的工具,用于诊断网络故障和分析网络性能问题。irptrace bug指的是irptrace工具中的错误或问题。 irptrace bug可能会导致以下问题: 1. 数据包丢失:irptrace工具可能无法正确跟踪特定的数据包,从而导致数据包丢失。这可能使得在分析网络故障或性能问题时无法得到完整的数据包信息。 2. 数据包误解释:irptrace工具在解释和显示跟踪到的数据包时,可能存在解析错误或误解释。这可能会导致分析人员对问题的理解出现偏差,从而影响故障排查和问题解决的准确性。 3. 流量捕获问题:irptrace可能无法正确捕获特定的网络流量,导致分析人员无法获得完整的数据包信息。这可能会给故障排查和网络性能分析带来困扰。 为解决irptrace bug,可以采取以下措施: 1. 更新工具版本:检查irptrace是否有更新的版本可用,并及时进行升级。新版本通常会修复之前版本存在的问题和错误。 2. 反馈问题:向irptrace的开发者或社区反馈发现的bug。提供详细的bug报告,包括复现步骤、操作环境以及出现的错误现象。这有助于开发者理解和解决bug。 3. 使用替代工具:如果irptrace存在严重的bug,且无法得到及时修复,可以考虑寻找替代的网络数据包跟踪工具,以满足分析需求。 总之,irptrace bug可能会对网络故障排查和性能分析造成不便和困扰。通过及时更新版本、反馈问题和使用替代工具,可以最大程度地减少bug带来的影响。 ### 回答2: irptrace bug是指在irptrace程序中存在的错误或缺陷。irptrace是一种用于追踪和分析网络中的IRP(Input/Output Request Packet)的工具。IRP是Windows操作系统中的一种数据结构,用于表示设备驱动程序之间的通信请求。 irptrace bug可能会导致程序运行时出现意外的行为或错误的输出。这些错误可能由以下原因引起: 1. 内存错误:在处理IRP时,程序可能会对内存进行错误的读写操作,导致数据损坏或程序崩溃。 2. 逻辑错误:IRP的处理可能存在逻辑错误,导致程序无法正确解析和响应IRP请求。 3. 并发问题:在多线程或多进程环境中,IRP的处理可能存在并发问题,导致数据竞争和不确定的行为。 解决irptrace bug的方法通常涉及以下步骤: 1. 重现bug:通过使用给定的输入或具体的测试用例来重现错误。这有助于开发者定位和理解bug的根本原因。 2. 调试:使用调试工具(如调试器或日志记录)跟踪程序执行的每个步骤,找出bug所在的代码位置。 3. 修复bug:根据调试结果,开发者需要改正或修复引起bug的代码。这可能包括修复内存错误、修改逻辑错误或解决并发问题。 4. 测试:对修复后的代码进行全面测试,确保在各种输入和使用情况下没有再次出现类似的bug。 最后,irptrace bug的修复应该通过软件版本控制和发布机制,将修复应用到所有受影响的版发布版本中,以确保用户可以使用到修复后的版本。这样可以提高irptrace的稳定性和可靠性。 ### 回答3: irptrace bug是指由于irptrace程序中的程序错误或漏洞导致的问题。irptrace是一种用于跟踪和分析网络协议包的工具,常用于网络故障排除和性能分析。然而,由于代码编写或设计上的错误,irptrace可能会出现一些bug,影响其正常运行和准确性。 irptrace bug的出现可能导致不正确的跟踪结果,或者在特定情况下导致程序崩溃。例如,一个常见的bug可能是irptrace在解析或处理特定类型的网络协议包时出现错误。这可能导致irptrace无法正确解码和显示相关信息,或者给出错误的跟踪结果。 修复irptrace bug需要进行代码审查和测试,以确定问题所在,并对代码进行修改和优化。开发人员需要仔细检查输入验证和边界情况处理,以确保代码的健壮性和鲁棒性。 此外,用户也可以通过向irptrace开发团队报告bug来促进修复。这通常包括提供复现bug所需的详细信息,例如操作系统版本、irptrace版本、复现bug的步骤和所使用的网络环境。这些信息将帮助开发人员更好地理解和定位bug,并更快地进行修复。 总之,irptrace bug是指由于irptrace程序中的错误或漏洞导致的问题。修复这些bug需要开发人员进行代码审查和测试,并且用户的报告也是促进修复的重要渠道。这样可以确保irptrace能够正常运行且给出准确的跟踪结果,提高网络故障排除和性能分析的效率和准确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值