問題出現:
一個老項目的退款功能被微信支付後臺停用,緣由是xml解析工具備漏洞風險, 微信客服給出的解決方案是使用官方的補丁。 使用補丁後發現:xml-api包與jdk自帶的包衝突。 具體緣由: xml-api包的某個類與jdk自帶的某個類具備相同的全限定名,可是xml-api包中並無相關實現, IDE沒有依賴jdk自帶的包,而是優先依賴xml-api包,致使項目沒法完成編譯。
嘗試解決:
在 Maven 中排除 xml-api 包: 從父 pom 裏面作排除: 可是項目年代久遠,各類類庫的依賴盤根錯節, 到父 pom 裏面沒找到依賴,到依賴的自定義基本庫裏面也沒找到。 何況考慮到父 pom 被其餘項目依賴的可能性,因此仍是想一想其餘辦法。 全局排除: 在 pom 文件里加入衝突包的依賴,而後再排除包裏所有的內容: <dependency> <groupId></groupId> <artifactId></artifactId> <version></version> <exclusions> <exclusion> <groupId>*</groupId> <artifactId>*</artifactId> </exclusion> </exclusions> </dependency> 這個方法可以排除掉項目對 xml-api 包裏的所有依賴; 可是由於先導入後排除,項目依然會優先依賴 xml-api 包;因此問題仍是沒有解決。
推薦方案:
修改依賴包的優先級: 由於這個老項目是用 Eclipse 開發,先說 Eclipse 操做方法。 Eclipse: 設置 build path order; 把優先級高的包放到上面, 因此能夠把 jre 的包放到最上面。 順便看了下 IDEA 的設置,也能修改優先級。 IDEA: 修改 classpath order: 菜單:File -> Project Structure -> Modules 快捷鍵:Ctrl + Alt + Shift + S -> Modules 把優先級高的包放到上面, IDEA 中,jdk 自帶的包默認就是最高優先級,因此使用 IDEA 不會出現相似的問題。
傳送門:http://blog.51cto.com/1350814...
本文系筆者原創
轉載請註明出處
—————————————api