类冲突的排查方法

1 增加了一个新的依赖,但是发现每次debug都不能匹配到正确的行数,以为是编译的行号和源代码的行号不一致导致的

 

2 要到了引入依赖的源码放到了项目中,作为一个子moudle引入并在包打包的时候重新编译,还是发现debug不到正确的源码

 

3 更改依赖源码的类名,结果发现可以走到正确的源码,于是怀疑项目环境中有一个低版本的同名类导致。

 

4 设置一个断点,用内存模式计算出类的codesouse,果然MyCommonSessionFilter还真的有一个从老的jar包中的引用,并且runtime阶段居然用的是老的class

 

4.1改过名字的类可以指向我引入的源码及编译的jar包中

Class.forName("com.xxx.xxx.filter.MyCommonSessionFilter").getProtectionDomain().getCodeSource()

153456_iRlw_195637.png

4.2老的jar包还真的有一个这个名字的类

Class.forName("com.xxx.xxx.filter.CommonSessionFilter").getProtectionDomain().getCodeSource()

153510_eeOY_195637.png

 

5 解决方案比较容易了,外层pom中找到这个jar包引入的地方(这个地方比较难排查的是这个jar包是一个依赖中的子依赖引入的,所以我最开始show dependcy tree的时候并没有打印出来),exclude掉即可

打印依赖树并保存 mvn -Dverbose dependency:tree >1.txt
 

转载于:https://my.oschina.net/zimingforever/blog/1525002

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值