从ServerHttpResponse Spring云网关读取响应正文

时间:2020-04-15 15:23:49

标签: spring spring-boot spring-cloud

我试图在扩展ServerHttpResponse的FilterFactory类中从AbstractGatewayFilterFactory读取响应正文。该方法执行,但是我从没看到打印日志行。这是读取回复的正确方法吗?如果是,我在这里想念什么?

@Override
public GatewayFilter apply(Config config) {
    return (exchange, chain) -> {
        ServerHttpRequest.Builder reqBuilder = exchange.getRequest().mutate();
        ServerHttpResponse originalResponse = exchange.getResponse();
        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.map(dataBuffer -> {
                        byte[] content = new byte[dataBuffer.readableByteCount()];
                        dataBuffer.read(content);
                        log.info("Response : {}", new String(content, StandardCharsets.UTF_8));
                        return bufferFactory.wrap(content);
                    }));
                }
                return super.writeWith(body);
            }
        }; 
        long start = System.currentTimeMillis();
        return chain.filter(exchange.mutate()
                .request(reqBuilder.build())
                .response(decoratedResponse)
                .build());
    };
}

0 个答案:

没有答案