激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|JAVA教程|ASP教程|

服務器之家 - 編程語言 - JAVA教程 - dom4j從jar包中讀取xml文件的方法

dom4j從jar包中讀取xml文件的方法

2019-11-05 11:35java技術網 JAVA教程

這篇文章主要介紹了dom4j從jar包中讀取xml文件的方法,需要的朋友可以參考下

進行封裝的時候,我們常常需要用xml來定義一些規范,在單獨運行讀取的時候當然不會有問題,但這些xml是往往是放在jar包里的,這樣一來,這些東西就找不出來了。文中用到的xml定義如下:

復制代碼代碼如下:

<?xml version="1.0" encoding="utf-8"?>
<ACCESOS>
 <item>
  <SOCIO name="adsf">
   <NUMERO>00045050</NUMERO>
   <REPOSICION>0</REPOSICION>
   <NOMBRE>MOISES MORENO</NOMBRE>
   <TURNOS>
    <LU>T1</LU>
    <MA>T2</MA>
    <MI>T3</MI>
    <JU>T4</JU>
    <VI>T5</VI>
    <SA>T6</SA>
    <DO>T7</DO>
   </TURNOS>
  </SOCIO>
 </item>
 <item>
  <SOCIO name="adsfa">
   <NUMERO>00045051</NUMERO>
   <REPOSICION>0</REPOSICION>
   <NOMBRE>RUTH PENA</NOMBRE>
   <TURNOS>
    <LU>S1</LU>
    <MA>S2</MA>
    <MI>S3</MI>
    <JU>S4</JU>
    <VI>S5</VI>
    <SA>S6</SA>
    <DO>S7</DO>
   </TURNOS>
  </SOCIO>
 </item>
</ACCESOS>

 

下面來看代碼:

復制代碼代碼如下:

public void read(){  
    try {  
        Document doc = new SAXReader().read(new File("src/user.xml"));  
        List<Element> itemList =  doc.selectNodes("/ACCESOS/item/SOCIO");  
        for (Iterator<Element> iter = itemList.iterator(); iter.hasNext();){  
            Element element = iter.next();  
            System.out.println("NUMERO =" + element.elementText("NUMERO"));  
        }  
    } catch (DocumentException e) {  
        e.printStackTrace();  
    }  
}  

 

這段代碼 寫在Java Project中,其中user.xml放在src根目錄下,類在src/com/jianxin/xml下,很顯然運行以上代碼是可以出來結果的,但如果把以上代碼打包,這個jar包內的目錄為
com/jianxin/xml
user.xml
而這里方法內還是去src下去找user.xml,就算把src/從路徑中去掉,仍然無法定位到jar中的user.xml上。
這主要是因為jar包是一個單獨的文件而非文件夾,絕對不能通過"file:/d:.../user.xml"這種形式來對文件定位,所以即使是相對路徑,也無法定位到jar文件內的文件。
那么把xml打入jar包,無論user.xml在哪個目錄下,jar包中的類都可以找到,這會是幻想嗎?
當然不是,我們可以用類裝載器(ClassLoader)來做到:
1)ClassLoader是類加載器的抽象類。它可以運行時動態的獲取加載類的運行信息。可以這樣說,當我們調用xml.jar中的ReadXML類時,JVM加載進ReadXML類,并記錄下ReadXML運行時信息(包括所在jar包的根路徑信息)。而ClassLoader類中的方法 可以幫助我們動態獲取這些信息:
a.public URL getResource(String),查找且有給定名稱的資源。
b.public InputStream getResourceAsStream(String name),返回指定資源輸入流
2)ClassLoader是abstract的,不可能實例化。我們真正寫代碼的時候,是通過Class類中的getResource和getResourceAsStream方法 ,這兩個方法會委托ClassLoader中的getResource和getResourceAsStream方法。現在對上面方法進行重寫:

 

復制代碼代碼如下:

public void read(){
 try {
     InputStream is=this.getClass().getResourceAsStream("/user.xml");
     Document doc = new SAXReader().read(is);
  List<Element> itemList =  doc.selectNodes("/ACCESOS/item/SOCIO");
  for (Iterator<Element> iter = itemList.iterator(); iter.hasNext();){
   Element element = iter.next();
   System.out.println("NUMERO =" + element.elementText("NUMERO"));
  }
 } catch (DocumentException e) {
  e.printStackTrace();
 }
}

 

這樣,打包之前運行是沒有問題的,打成包后,依然是可以運行找到數據的~。
在這里我感覺最重要的就是獲取Class同時會獲取jar根目錄信息,同時ClassLoader也會有所改變,這點需要注意一下,至于到底是什么改變,目前我也說不上來,只是碰到了這樣的問題。所以計劃看一本Java比較底層的書,以讓自己在為別人封裝東西的時候更加得心就手,一直停留在應用層次的我們,也是時候深入了解一下JVM了。
最近大部分時間都是在開發,說好的jira可能會更晚些,做的過程中,做是用了一下dwr,下篇對其進行描述~~~

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 中文字幕极速在线观看 | 精国产品一区二区三区四季综 | 日韩精品一区二区久久 | 欧美3p激情一区二区三区猛视频 | 法国性经典xxxhd | 91成人免费视频 | 日本欧美一区二区三区在线观看 | 国产午夜亚洲精品 | 91精品老司机 | 成人免费精品视频 | 久久成人视屏 | 九九黄色| 国产自91精品一区二区 | 久久国产一级片 | 久久久久久中文字幕 | 国产91久久久久久 | 精品一区二区在线视频 | 人人看人人舔 | 色阁五月 | 国产成人精品午夜视频' | 亚洲情视频 | 成人久久免费 | www.91sp| 99亚洲伊人久久精品影院红桃 | 亚洲国产成人一区二区 | 看一级毛片 | 香蕉成人在线视频 | 国产美女一区二区在线观看 | 九九热在线视频观看这里只有精品 | 美女黄页网站免费进入 | 久久99亚洲精品久久99果 | 成人在线视频精品 | 欧美三日本三级少妇三级99观看视频 | 天天碰夜夜操 | 欧美精品免费一区二区三区 | 国产免费观看电影网站 | 免费观看黄色一级视频 | 中文字幕涩涩久久乱小说 | 久久精品2019中文字幕 | 国产精品亚洲综合一区二区三区 | 免费观看的毛片手机视频 |