今天在开发网关自定义审计功能时发现,写的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去重。
|