jar包衝突了?如何肯定是和哪一個jar包衝突了?

導讀:工程編譯的時候好好地,怎麼一運行就報各類的NoSuch***Error,猜想多是jar包衝突了,可是到底是和哪一個jar包衝突了呢。java

關鍵詞:jar包衝突,NoSuchFileldError,NoSuchMethodErrorjson

問題背景maven

前段時間寫代碼的時候想借助一下fastjson的Feature.OrderedField來解決json亂序的問題,只須要增長一個參數便可,像下面這樣ide

JSON.parseObject("...", Feature.OrderedField)

 

,idea檢查是沒有任何問題的,可是跑單元測試的時候居然報NoSuchFiledError(找不到Feature.OrderField),我猜想多是jar包衝突了,因此下一步就是找出究竟是和哪一個jar包衝突了。工具

解決方法一單元測試

最開始我覺得是maven傳遞依賴了老版本的fastjson包,全部我嘗試使用「mvn dependency:tree」來輸出項目中的全部jar包依賴一看究竟,可是結果讓人大跌眼鏡,整個項目只依賴了1.2.58版本的fastjson包,傳遞依賴的猜想隨之破滅。測試

解決方法二url

我仔細分析了報錯的堆棧信息,報錯只是說Field找不到,可是Field所屬的Class是能夠找到的,那有沒有一種辦法能夠經過Class找到所屬的jar包呢?最終經過度娘找到了一種辦法,貼出來供你們使用idea

 
try{
  JSON.parseObject("...", Feature.OrderedField)
}catch(Throwable e){
    String loc = ""; 
     String urlLoc = ""; 
     try {     
       loc = 
       
      Feature.class.getProtectionDomain().getCodeSource().getLocation().getFile(); 
      urlLoc =  URLDecoder.decode(loc, "UTF-8"); 
   } catch (Throwable e2) { 
     
   } 
    
   logger.info("** loc=" + LOCATION + "; URLLoc=" + URLLOCATION);
}
  

  

水落石出spa

最終找到了致使衝突的jar原來是公司自研的消息隊列提供的producer client,在這個jar包內部將fastjson的源碼直接打到了jar包裏面,因此在不一樣的jar包內居然出現了包名和類名都同樣的class,下面這個圖是jar包內部的目錄結構,這種使用第三方工具包的方式我也是第一次見,感受挺坑的(耦合太嚴重),最終我沒有使用fastjson來解決個人問題,而是藉助了Gson將這個問題繞過去了。

 

 

總結

主要介紹了兩種找出衝突jar包的方式,第一種是使用「mvn dependency:tree」的方式,可是這種方式存在侷限性,就像前面說到的那種,兩個看似不相干的jar包內居然出現了包名和類名都同樣的class,第二種是直接經過class對象獲取jar包全路徑的方式,這種方式更通用,可是須要改動一點代碼。

十一假期最後一天,祝你們返程愉快,若是以爲對你有用,請點一下推薦。

相關文章
相關標籤/搜索