Java Flux contains_自定义Spring Webflux 过滤器,解决请求body只能获取一次的问题

Webflux 和 servlet一样body只能获取一次,解决办法也是一样的,自定义请求包装类参考大神博客

1 背景

为了测试和调试方便打印请求和返回的报文信息。一般可以通过Aop拦截controller方法或增加过滤器打印报文信息解决。

1.1 Aop方法

使用Aop的拦截controller方法,是将方法的model对象参数转成json打印出来,因为是body字符串通过httpMessageConverter转成model对象,在这里打印的话就是又转回body字符串。有点浪费性能。

1.2 增加自定义过滤器的方法

自定义过滤器的话放在第一个过滤器,在转换成对象之前就打印,这样可以减少多余的性能消耗。

2 Webflux创建请求和返回的的装饰类

2.1 Request装饰类

创建包装类PartnerServerHttpRequestDecorator继承ServerHttpRequestDecorator,在含参构造放中打印请求url,query,headers和报文信息。

@Slf4j//lombok插件

public class PartnerServerHttpRequestDecorator extends ServerHttpRequestDecorator {

private Flux body;

PartnerServerHttpRequestDecorator(ServerHttpRequest delegate) {

super(delegate);

final String path = delegate.getURI().getPath();

final String query = delegate.getURI().getQuery();

final String method = Optional.ofNullable(delegate.getMethod()).orElse(HttpMethod.GET).name();

final String headers = delegate.getHeaders().entrySet()

.stream()

.map(entry -> " " + entry.getKey() + ": [" + String.join(";", entry.getValue()) + "]")

.collect(Collectors.joining("\n"));

final MediaType contentType = delegate.getHeaders().getContentType();

if (log.isDebugEnabled()) {

log.debug("\n" +

"HttpMethod : {}\n" +

"Uri : {}\n" +

"Headers : \n" +

"{}", method, path + (StringUtils.isEmpty(query) ? "" : "?" + query), headers);

}

Flux flux = super.getBody();

if (LogUtils.legalLogMediaTypes.contai

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值