springcloud gateway 重复执行filter的解决方案

在开发Spring Cloud Gateway自定义审计功能时遇到filter执行两次的问题,与已知案例相同。解决方案是通过请求ID进行去重,从Header中获取请求ID,如果Redis中已存在相同ID,则避免再次执行。这种方法可以有效防止同一次请求被处理多次。
摘要由CSDN通过智能技术生成

今天在开发网关自定义审计功能时发现,写的filter每次请求都会被执行了两次。

具体情况和这位仁兄相同:

springcloudgateway 重复执行filter_g3230863的博客-CSDN博客springcloudgateway 重复执行filter执行的核心方法:遍历所以的filter其中有一个自定义的filter排在NettyWriteResponseFilter 之后当index=13执行完所有的filter,返回Mono.empty()。然后执行CorsResponseHeaderFilter的 chain.filter(exchange).then()方法后,又调用了return chain.filter(exchange); 把他下面的filter又执行了一次@https://blog.csdn.net/g3230863/article/details/119637318

以下给出我的具体解决方案:

想法思路:由于是同一次请求,那么请求ID一定是相同的,直接处理掉重复的ID就好了。

//从Header中获取用户信息
ServerHttpRequest request = exchange.getRequest();
log.info("请求ID:{}",request.getId());
String Key = "Request:ID:" + request.getId();
if (redisTemplate.hasKey(Key)) {
    byte[] uppedContent = new String(content, Charset.forName("UTF-8")).getBytes();
    return bufferFactory.wrap(uppedContent);
}
redisTemplate.opsForValue().set(Key, 1, 10, TimeUnit.SECONDS);
//do somethings

当然也可以使用map等方式实现,选择处理方式随意,重点就是拿请求ID去重。

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值