博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
类冲突的排查方法
阅读量:6454 次
发布时间:2019-06-23

本文共 712 字,大约阅读时间需要 2 分钟。

hot3.png

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

你可能感兴趣的文章
OC中使用 static 、 extern、 const使用
查看>>
简单理解函数回调——同步回调与异步回调
查看>>
POJ 1007
查看>>
Android 多个Activity 跳转及传参
查看>>
中文文本预处理流程(带你分析每一步)
查看>>
anroid 广播
查看>>
AJAX POST&跨域 解决方案 - CORS
查看>>
如何设计企业内部的数据平台?
查看>>
关于最小生成树中的kruskal算法中判断两个点是否在同一个连通分量的方法总结...
查看>>
【译】Linux系统和性能监控(4)
查看>>
开篇,博客的申请理由
查看>>
点滴积累【C#】---C#实现上传word以流形式保存到数据库和读取数据库中的word文件。...
查看>>
Ubuntu常用笔记
查看>>
Token和session 详解
查看>>
JMeter IP欺骗压测
查看>>
Serializers 序列化组件
查看>>
最简单的RPC框架实现
查看>>
Servlet 技术全总结 (已完成,不定期增加内容)
查看>>
[JSOI2008]星球大战starwar BZOJ1015
查看>>
CountDownLatch与thread-join()的区别
查看>>