今天在开发网关自定义审计功能时发现,写的filter每次请求都会被执行了两次。
具体情况和这位仁兄相同:
以下给出我的具体解决方案:
想法思路:由于是同一次请求,那么请求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去重。