麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JSP > 正文

JSP針對XML文件操作技巧實例分析

2024-09-05 00:22:25
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了JSP針對XML文件操作技巧,較為詳細的分析了XML文件的相關概念、原理、用途,并結合實例介紹了基于JSP解析XML文件的相關技巧,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例講述了JSP針對XML文件操作技巧。分享給大家供大家參考,具體如下:

XML(Extensible Markup Language)可擴展標記語言,這個基礎知識在早些已經學習過。而這篇教程為什么把它放在J2EE下邊呢,因為他也是J2EE的13規范之一,雖然XML是W3C萬維網組織聯盟指定的,并做了規范,所以說也是一種規范,我們也必須按照規范來,和JDBC,Servlet,Jsp,Ejb等一樣的。

前邊的文章已經介紹了XML的一些基礎知識,主要是用來存儲,傳輸數據的,但是這些數據我們怎么得到呢,也就是說怎么來解析XML呢?這里總結一下。

首先解析XML文件一般有兩種方式:DOM解析和SAX解析,首先看一下兩者的概念和基礎知識:

一,原理:

DOM解析:在程序開始執行的時候,先將整個XML文件加載到內存中,在內存中形成一棵DOM樹,然后通過某種編程語言對這顆樹上的任意節點進行增刪改查操作。

SAX解析:基于事件驅動型的解析方式。解析是有順序的,順序遵守:從左到右,從上到下。

基于事件驅動型的解析方式不需要將XML文件全部加載到內存中,所以這種方式不會耗費大量的內存,

只不過解析過去的節點不能再次解析,不夠靈活,如果還想解析,只能再次從XML文件頭開始。

二,兩者的優缺點:

DOM解析:優點:靈活。因為整個樹都在內存中,我們隨時隨地都可以對某個節點操作,解析過去的節點還可以再次解析,比較靈活。

缺點:如果XML文件很大,則會耗費大量的內存,因為這個XML文件很大,而需要訪問

的節點又很少。

總結: 所以XML文件較小、需要解析的節點較多,這樣才值得使用DOM解析。

SAX解析:優點:不會耗費大量的內存。

缺點:不靈活(我們可以使用另外一個技術XPATH,使用它可以在XML文件中快速定位要

解析的節點)。

總結:有了XPath技術,SAX解析方式成為我們常用的。

三,在JAVA中,java的JDK提供了關于XML的解析

:org.w3c.dom.*,這是SUN對w3c規范的實現。但是效率,不夠高。所以我們經常使用第三方組件,例如dom4j等,效率相對來說較高一些。

四,好,我們來看一下實例吧:

1,利用JAVA中的JDK提供的,來進行解析讀XML文件:來看兩篇博客寫的很詳細的:Java Dom解析,Java Sax解析。

2,這里寫一下,利用dom4j的解析方法,其實很相同,只不過我感覺dom4j的方法名,屬性名可能更容易使用:

a, 讀XML文件(以下是基于SAX解析方式):

 

 
  1. public static void main(String[] args) throws Exception{  
  2. //創建SAX解析器對象  
  3. SAXReader reader = new SAXReader();  
  4. //讀取XML文件  
  5. Document document = reader.read(new File("db-config.xml"));  
  6. //獲取根元素  
  7. Element rootElement = document.getRootElement();  
  8. System.out.println("根節點的名字:" + rootElement.getName());  
  9. //獲取根節點下的子節點driver  
  10. Element driverElement = rootElement.element("driver");  
  11. String driver = driverElement.getText();  
  12. System.out.println(driver);  
  13. //獲取根節點下的子節點url  
  14. String url = rootElement.elementText("url");  
  15. System.out.println(url);  
  16. //獲取根節點下的子節點user  
  17. String user = rootElement.elementText("user");  
  18. System.out.println(user);  
  19. //獲取根節點下的子節點password  
  20. String password = rootElement.elementText("password");  
  21. System.out.println(password);  
  22. }  

b,寫文件,就是從上向下的了,我們dom4j中的DOM解析的方式:

 

 
  1. public static void main(String[] args) throws Exception{  
  2. //在內存中先創建一個文檔對象  
  3. Document document = DocumentHelper.createDocument();  
  4. //構造文檔樹  
  5. Element stuInfoElement = document.addElement("數學專業書籍");  
  6. Element stuElement1 = stuInfoElement.addElement("書");  
  7. stuElement1.addAttribute("id""110");  
  8. Element nameElement1 = stuElement1.addElement("書名");  
  9. nameElement1.setText("近世代數");  
  10. Element stuElement2 = stuInfoElement.addElement("書");  
  11. stuElement2.addAttribute("id""120");  
  12. Element nameElement2 = stuElement2.addElement("書名");  
  13. nameElement2.setText("高等代數");  
  14. //設置字符編碼方式  
  15. OutputFormat format = OutputFormat.createPrettyPrint();  
  16. format.setEncoding("GB18030");  
  17. //開始寫入  
  18. XMLWriter xmlWriter = new XMLWriter(new FileWriter("students.xml"),format);  
  19. xmlWriter.write(document);  
  20. xmlWriter.close();  
  21. }  

最后寫成的文件:

 

 
  1. <?xml version="1.0" encoding="GB18030"?>  
  2. <數學專業書籍>  
  3. <書 id="110">  
  4. <書名>張三</書名>  
  5. </書>  
  6. <書 id="110">  
  7. <書名>張三</書名>  
  8. </書>  
  9. </數學專業書籍>  

綜上,為XML解析的簡單總結,當然實際中會遇到非常復雜的XML文件,我們可以自己來試著寫這些解析他們的文件,當然也可以使用人家寫好的,這里只是為了多學習,理解它們的本質。

希望本文所述對大家JSP程序設計有所幫助。


注:相關教程知識閱讀請移步到JSP教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 深夜免费视频 | 国产亚洲精品久久久久5区 综合激情网 | 最新一区二区三区 | 羞羞视频免费入口网站 | av在线更新 | 91中文字幕在线观看 | 看免费毛片 | 99影视电影电视剧在线播放 | 日本aaaa片毛片免费观蜜桃 | 天天操综 | 国产99视频在线观看 | 精品一区二区三区在线播放 | 极品xxxx欧美一区二区 | 少妇一级淫片免费放播放 | 国产精品视频中文字幕 | 国产99久久精品一区二区300 | 国产一区二区亚洲 | 黄色视屏免费在线观看 | 日日草夜夜 | 久久久一二三 | 黄色网址在线视频 | 久久亚洲精选 | 欧美一级电影网 | 免费观看视频网站 | 亚洲国产一区二区三区 | 亚洲五码在线观看视频 | 日韩区在线 | 九九热免费精品 | 久久久久一本一区二区青青蜜月 | 毛片免费观看视频 | 色婷婷久久久 | 日本欧美中文字幕 | 91av网址| 久草最新网址 | 国产日韩一区二区三区在线观看 | 国产一区二区免费在线观看 | 国产精品999在线观看 | 欧美日韩1区2区3区 黄片毛片一级 | 手机黄色小视频 | 国产亚洲精品一区二区三区 | 一本免费视频 |