Spring中拦截器重复注册的问题排查

注册器JpushInterceptor

功能:新版的Java推送服务,将部分请求转发到老版node

查看日志发现拦截器日志重复

同一个链路,发现,经过同一个拦截器两次
image.png

debug发现注册器重复注册

image.png

第一个通过registry.addInterceptor注册

是通过WebMvcConfigurer的钩子注册的
在这里插入图片描述

第二个通过bean类型中注册

因为使用了op3(公司内部对Spring二次开发的),版本:3.2.3.RELEASE

通过@Component将JpushInterceptor声明为了Spring Bean
在这里插入图片描述

OpWebAutoConfiguration通过beanType将其注册,链路如下:
DelegatingWebMvcConfiguration.requestMappingHandlerMapping()
-> getInterceptors()

-> OpWebAutoConfiguration.addInterceptors
![image.png](https://img-blog.csdnimg.cn/img_convert/3f176c28044f77059bf27e9814314b38.png#averageHue=#212120&clientId=u1e131981-f784-4&crop=0&crop=0&crop=1&crop=1&from=paste&height=1702&id=uc582c998&margin=[object Object]&name=image.png&originHeight=1702&originWidth=2006&originalType=binary&ratio=1&rotation=0&showTitle=false&size=441590&status=done&style=none&taskId=u56e925bd-53b1-44b3-b40e-4b839c8e500&title=&width=2006)

关于通过bean类型方式的注册

spring文档上描述,支持的拦截器注册的方法只有下面的方式(即同上述第一种方式,通过javaconfig或者xml配置)

https://docs.spring.io/spring-framework/docs/current/reference/html/web.html#mvc-config-interceptors
在这里插入图片描述

并不支持上述根据bean类型注册。

op3支持按类型,自动注册拦截器
看op4上面的代码已经没了

解决方案

移除JpushInterceptor上的@Component注解
在这里插入图片描述

  • 本周二上预发,周四发布生产

结论

公司内对Spring二次开发,但个别情况没有考虑周全,用户代码总是千奇百怪的

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lanicc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值