作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我已经实现了自定义 ServerHttpRequestDecorator 来获取请求正文,但无法对响应执行相同的操作。
@Override
public Mono<Void> filter(ServerWebExchange exchange, WebFilterChain chain)
{
long start = System.currentTimeMillis();
LogServerWebExchangeDecorator exchangeDecorator = new LogServerWebExchangeDecorator(
exchange);
exchangeDecorator.getResponse().beforeCommit(() ->
{
logRequest(exchangeDecorator.getRequest(), exchangeDecorator.getRequestBody());
logResponse(exchangeDecorator.getRequest(), exchangeDecorator.getResponse(), start);
return Mono.empty();
});
return chain.filter(exchangeDecorator);
}
怎样才能达到同样的效果?
最佳答案
private class LogServerHttpResponseDecorator extends ServerHttpResponseDecorator
{
private final FastByteArrayOutputStream fastByteArrayOutputStream;
public LogServerHttpResponseDecorator(ServerHttpResponse response, LoggingContext loggingContext)
{
super(response);
fastByteArrayOutputStream = new FastByteArrayOutputStream();
response.beforeCommit(LoggingContextUtils.withContext(loggingContext, (Supplier<Mono<Void>>) () ->
{
logResponse(byteArrayToString(fastByteArrayOutputStream.toByteArray(),
getHeaders()));
return Mono.empty();
}));
}
@Override
public Mono<Void> writeWith(Publisher<? extends DataBuffer> body)
{
return super.writeWith(Flux.from(body).map(buffer ->
{
readBuffer(fastByteArrayOutputStream, buffer);
return buffer;
}));
}
@Override
public Mono<Void> writeAndFlushWith(
Publisher<? extends Publisher<? extends DataBuffer>> body)
{
return super.writeAndFlushWith(Flux.from(body).map(publisher ->
Flux.from(publisher).map(buffer ->
{
readBuffer(fastByteArrayOutputStream, buffer);
return buffer;
})));
}
}
private void readBuffer(FastByteArrayOutputStream fastByteArrayOutputStream, DataBuffer buffer)
{
try
{
Channels.newChannel(fastByteArrayOutputStream)
.write(buffer.asByteBuffer().asReadOnlyBuffer());
}
catch (IOException e)
{
if (LoggingUtils.isLoggable(LOGGER, Level.ERROR))
{
LoggingUtils.log(LOGGER, Level.ERROR, null, "Unable to log", e);
}
}
}
关于Java Web Flux : How to fetch body from ServerHttpResponse?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57011489/
想要在 Spring API Gateway 之上实现代理来记录请求/响应。我为传入请求和传出响应定义了自己的过滤器。 请求网关过滤器: public class RequestGatewayFilt
我已经实现了自定义 ServerHttpRequestDecorator 来获取请求正文,但无法对响应执行相同的操作。 @Override public Mono filter(ServerW
我是一名优秀的程序员,十分优秀!