Java Web Flux : How to fetch body from ServerHttpResponse?(Java Web Flux:如何从ServerHttpResponse获取正文?)
本文介绍了Java Web Flux:如何从ServerHttpResponse获取正文?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我已实现自定义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:如何从ServerHttpResponse获取正文?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Java Web Flux:如何从ServerHttpResponse获取正文?
基础教程推荐
猜你喜欢
- Spring Boot Freemarker从2.2.0升级失败 2022-01-01
- 如何使用 Eclipse 检查调试符号状态? 2022-01-01
- 如何强制对超级方法进行多态调用? 2022-01-01
- 如何对 HashSet 进行排序? 2022-01-01
- 如何在不安装整个 WTP 包的情况下将 Tomcat 8 添加到 Eclipse Kepler 2022-01-01
- Java 中保存最后 N 个元素的大小受限队列 2022-01-01
- 如何使用 Stream 在集合中拆分奇数和偶数以及两者的总和 2022-01-01
- 由于对所需库 rt.jar 的限制,对类的访问限制? 2022-01-01
- 首次使用 Hadoop,MapReduce Job 不运行 Reduce Phase 2022-01-01
- 在螺旋中写一个字符串 2022-01-01