Чтение тела ответа из облачного шлюза ServerHttpResponse Spring - PullRequest
0 голосов
/ 15 апреля 2020

Я пытаюсь прочитать тело ответа из 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());
    };
}
...