在我的项目中,有两个库,每个库都依赖于XML解析类java.xml.parsers.DocumentBuilderFactory。这些库中的每一个都引用来自不同jar的文件(一个从名为xmlParserAPIs的jar中获取该文件,另一个从xml-apis-1.0.b2.jar中获取该文件)。不幸的是,在每个文件中都有不同版本的类,所以我看到了运行时错误,这取决于它们的加载顺序。这两个xml jars都是第三方库的传递依赖项。有没有处理这种冲突的好方法?
编辑:我不确定这对如何处理问题是否有影响,但这只会在测试中发生,因为其中一个依赖项在测试范围内。
谢谢,杰夫
发布于 2010-07-07 05:23:40
(...)不幸的是,在每个文件中都有不同版本的类,所以我看到了运行时错误,这取决于它们的加载顺序。
从理论上讲,xml-apis.jar和xmlParserAPIs.jar (来自xerces2-j)是相同的JAR,但名称不同,xmlParserAPIs.jar多年来一直被弃用(参见this message和this one)。
如果您的依赖项依赖于不同且不兼容的xml-apis.jar版本,我会说这些依赖项是相互排斥的,换句话说,至少对于您正在使用的版本是不兼容的。唯一的解决方案是找到具有收敛依赖的版本。
如果它们可以使用兼容的版本,请使用xmlParserAPIs.jar的依赖项exclusion,以便仅使用xml-api.jar。
我不确定这对如何处理问题是否有影响,但这只会在测试中发生,因为其中一个依赖项在测试范围内。
不,这只是解释了为什么你在运行时没有得到这个问题(因为test作用域不在类路径上,很明显,没有冲突)。
https://stackoverflow.com/questions/3190216
复制相似问题