欢迎来到三一办公! | 帮助中心 三一办公31ppt.com(应用文档模板下载平台)
三一办公
全部分类
  • 办公文档>
  • PPT模板>
  • 建筑/施工/环境>
  • 毕业设计>
  • 工程图纸>
  • 教育教学>
  • 素材源码>
  • 生活休闲>
  • 临时分类>
  • ImageVerifierCode 换一换
    首页 三一办公 > 资源分类 > PPT文档下载  

    【教学课件】第10章XMLDOM物件模型.ppt

    • 资源ID:5657599       资源大小:1.04MB        全文页数:85页
    • 资源格式: PPT        下载积分:15金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要15金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    【教学课件】第10章XMLDOM物件模型.ppt

    第10章 XML DOM物件模型,DOM 的基礎JAXP API 的基礎在 Java 程式載入和剖析 XML 文件DOM 的節點介面XML 文件的驗證XPath/XSLT 與 Java,General Purpose XML Programming,Needed for:domain-specific applicationsimplementing new generic toolsImportant constituents:parsing XML documents into XML treesnavigating through XML treesmanipulating XML treesserializing XML trees as XML documents,XML程式設計,一般來說,XML剖析器主要有兩種類型:樹狀基礎的剖析器(Tree-based Parser):將XML文件轉換成樹狀結構剖析器需要分析完整份XML文件後提供相關介面物件來存取樹狀結構的節點,例如:DOM、JDOM、JAXP APIs。事件基礎的剖析器(Event-based Parser):讀取內容時觸發一系列事件,應用程式提供函數處理這些事件,以便存取XML內容,例如:SAX(Simple API for XML)。,Parsing Events,View the XML document as a stream of events:the document startsa start tag is encounteredan end tag is encountereda namespace declaration is seensome whitespace is seencharacter data is encounteredthe document endsThe SAX tool observes these events It reacts by calling corresponding methods specified by the programmer,DOM vs.SAX,Memory consumption:The JDOM version:on 18MB documentThe SAX version handles 1.2GB in 51 secondsTree Navigation is easier for DOM;especially when backward traversal is necessary.,什麼是DOM,DOM(Document Object Model)物件模型可以將一份結構化文件轉換成一棵由節點(Nodes)組成的樹狀結構,提供節點的相關屬性和方法來存取元素內容,或新增、刪除和修改節點內容,如下圖所示:,什麼是W3C DOM,DOM 是 W3C 建議規格Designed with language independenceDOM Level 1 在 1998 年 10 月 1 日成為 W3C 的建議規格,DOM Level 2 是在2000 年 11 月成為建議規格,目前最新版本是 Level 3,W3C DOM的特點,跨平台和程式語言的程式介面支援多種結構化文件W3C DOM 支援 HTML 和 XML 文件支援多種程式語言JavaScript、VBScript、Perl、Visual Basic、Delphi、C+、PHP 和 Java 等程式語言。支援多種文件驗證DOM 支援 DTD、XML Schema 等 XML 文件驗證。,W3C DOM基礎的文件分析,例如:一份XML文件,如下所示:01:02:03:Java 2程式設計範例教本04:陳會安05:65006:07:,XML的DOM樹,以 W3C DOM 的角度來看,前頁的 XML 文件就是一棵樹狀結構的節點資料,以 Java 語言來說,就是一個 Document 物件,如下圖所示:,什麼是JAXP,之前已經說過了,要處理 XML 文件,首先這份文件都必須先經過 parser 來解析。XML 的 parser 有非常多種,比較著名的有 Apache 的 Xerces、Crimson 等;只可惜這些 parser 所提供的 APIs 並不相通(這跟當初設計 DOM APIs 時的想法不同)。Suns JAXP(Java API for XML Parsing)提供通用介面使得 Java 程式使用任意符合 JAXP 介面的 parser 來處理 XML 文件。JAXP 支援 Crimson、Xerces 等 XML parsersJAXP 支援 XML、SAX、XPath、XSLT 等標準JAXP vs.JDOMJDOM requires extra installationJDOM does not directly support XSLT,什麼是JAXP,JAXP API 的主要套件是 javax.xml.parsers 套件提供與開發廠商無關的通用 API 來使用 DOM 和 SAX 剖析和驗證 XML 文件。在 javax.xml.parsers 套件主要包含兩個代理商類別(Factory Classes),如下所示:DocumentBuilderFactory 類別:自動選取某一 parser 類別(ex.Xerces),來產生 DocumentBuilderFactory 的物件利用現有的 configuration 來產生 DocumentBuilder 實例。SAXParserFactory類別:可以取得 SAXParser 實例來處理 SAX 事件基礎的 XML 剖析。,JAXP API 的相關套件,JAXP API 提供 DOM 和 SAX 剖析和驗證的常用套件,如下表所示:,DOM API-說明,JAXP API 的 DOM API(Document Object Model API)是使用 javax.xml.parsers 套件的 DocumentBuilderFactory 類別來取得DocumentBuilder 實例,以便建立 DOM 樹狀結構節點的 Document 物件,如下圖所示:,DOM API-介面物件,將 XML 文件內容視為一個樹狀結構的節點,其主要的介面物件,如下表所示:,載入與剖析XML文件檔案,在 Java 程式載入與剖析 XML 檔案,首先需要匯入 JAXP API 的相關套件,如下所示:import javax.xml.parsers.*;import org.xml.sax.*;import org.w3c.dom.*;程式碼匯入 XML 剖析器和 DOM 的相關套件,至於 org.xml.sax.*套件是剖析錯誤處理的相關套件。此外因為 XML 檔案是文字檔案,所以需要匯入檔案處理套件,如下所示:import java.io.*;,載入與剖析XML文件檔案,String filename=“Books.xml”;DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();try DocumentBuilder db=dbf.newDocumentBuilder();Document document=db.parse(new File(filename);catch(SAXException se)se.printStackTrace();catch(ParserConfigurationException pe)pe.printStackTrace();catch(IOException ie)ie.printStackTrace();,設定剖析器的參數,DocumentBuilderFactory 類別提供相關方法可以利用 configuration 來設定 XML 剖析器的功能或者特性是否忽略註解文字或空白字元的 XML 元素等例如:設定剖析器參數來忽略註解節點、空白字元(需要配合 DTD)和不轉換 CDATA 節點,如下所示:/設定剖析的參數dbf.setIgnoringComments(true);dbf.setIgnoringElementContentWhitespace(true);dbf.setCoalescing(false);,使用DTD驗證,JAXP 從 API 1.1 版就開始支援 DTD 驗證,只需在DocumentBuilderFactory 物件使用setValidating()方法設定參數為 true,就可以驗證XML文件,如下所示:dbf.setValidating(true);參數 true 表示 XML 剖析器需要驗證 XML 文件,預設是 DTD 驗證;如果設為 false,剖析器就不會進行文件驗證。,Ch10_5_1,import javax.xml.parsers.*;import org.xml.sax.*;import java.io.*;public class Ch10_5_1 public static void main(String args)String filename=Ch10-5-1.xml;DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();try dbf.setValidating(true);/設定剖析的參數 dbf.setIgnoringComments(false);dbf.setIgnoringElementContentWhitespace(false);dbf.setCoalescing(false);DocumentBuilder db=dbf.newDocumentBuilder();/剖析XML文件 db.parse(new File(filename);System.out.println(XML文件:+filename+剖析成功!);catch(ParserConfigurationException pe)System.out.println(剖析器設定錯誤!);catch(IOException ie)System.out.println(檔案處理錯誤!);catch(SAXException se)System.out.print(“XML剖析錯誤);System.out.println(se.getMessage();,範例:Books.xml,function hello()alert(Hello World);PHP 5網頁設計範例教本 陳會安 600 2005 JSP 2.0網頁設計範例教本 陳會安研究室 650 2004,Ch10_3_1 修改版,import javax.xml.parsers.*;import org.xml.sax.*;import org.w3c.dom.*;import java.io.*;public class Ch10_3_1 static Document document;public static void main(String args)String filename=Books.xml;DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();/dbf.setIgnoringElementContentWhitespace(true);try DocumentBuilder db=dbf.newDocumentBuilder();/讀入XML文件 document=db.parse(new File(filename);/Document 也是 Node 的一種 System.out.println(getID(document);/取得文件的根節點,這兩種方式略有不同!/Node root=document.getDocumentElement();Node child=(Node)document.getFirstChild();,讀取 Books.xml 的內容,並將每一個節點的節點型態、節點名稱等依照樹狀結構列印出來。,請觀察設定有無的差異!,Ch10_3_1 修改版,/取得這一層的所有節點 for(;child!=null;child=child.getNextSibling()System.out.print(getID(child);pChild(child,0);catch(SAXException se)/剖析過程錯誤 se.printStackTrace();catch(ParserConfigurationException pe)pe.printStackTrace();/剖析器設定錯誤 catch(IOException ie)ie.printStackTrace();/檔案處理錯誤,Ch10_3_1 修改版,/練習題:請補上其他的節點型態/程設的補充:這就是多型的應用 private static String getID(Node n)int type=n.getNodeType();switch(type)case 1:return 元素:+n.getNodeName();case 3:return 內容:+n.getNodeValue().trim();case 4:return CDATA Section:+n.getNodeValue();case 6:return 實體名稱:+n.getNodeName();case 8:return 註解:+n.getNodeValue();case 9:return Document:+n.getNodeName();case 10:return DOCTYPE:+(DocumentType)n).getSystemId();default:return 尚未定義:+type;,Ch10_3_1 修改版,/顯示子節點的遞迴方法 private static void pChild(Node temp,int pos)if(temp.hasChildNodes()NodeList nodes=temp.getChildNodes();/取得所有子節點 for(int i=0;i nodes.getLength();i+)int type=nodes.item(i).getNodeType();printIndent(pos);System.out.println(getID(nodes.item(i);if(type=Node.ELEMENT_NODE)pChild(nodes.item(i),pos+1);/顯示縮排所需的字元 private static void printIndent(int num)System.out.print(+);for(int i=0;i=num;i+)System.out.print(-);,Node節點種類,Document文件物件,XML 文件建立的樹狀結構是 Document 物件(可以想成之前說過的 root node)當 DOM 載入 XML 文件建立 Document 物件後,就可以使用 getDocumentElement()方法取得 XML 文件的根元素,如下所示:Node root=document.getDocumentElement();取出的每一個節點都是一個 Node 物件。Document 物件還提供特殊的方法,能夠直接使用標籤名稱取得所有為該名稱的節點,如下所示:NodeList tagNodes=document.getElementsByTagName(book);Note:Document 是 Node 的子類別,Node 節點物件,Node 節點物件許多方法:程式碼使用 getNodeName()方法取得節點的節點名稱若一個節點 root 擁有多個子節點,我們可以取得該節點下的所有子節點:NodeList nodes=root.getChildNodes();另外,還有 getNodeValue()和 getAttributes(),Node 節點物件,Node 節點物件還提供更多方法能夠瀏覽XML 文件來取得指定節點,相關方法的說明,如下表所示:,NodeList 節點清單的集合物件,當在 Java 程式呼叫 getChildNodes()方法,或是 getElementByTagName()方法取得指定節點時,這些節點是一個 NodeList 集合物件(也就是類似 List 的結構),而每一個節點包含該節點和其子節點的一棵子樹。在 NodeList 物件的 getLength()方法可以取得共擁有多少個節點。例如:使用 for 迴圈顯示所有NodeList 物件的節點,如下所示:NodeList nodes=root.getChildNodes();for(int i=0;i nodes.getLength();i+)System.out.println(元素:+nodes.item(i).getNodeName();,NodeList 節點清單的集合物件,Node節點物件的 getChildNodes()方法可以在樹狀結構的節點取得所需的子節點,如下所示:System.out.print(root.getChildNodes().item(1).getChildNodes().item(2).getNodeName();程式碼在取得根節點 root 物件後,使用getChildNodes()方法取得下一層第 2 個節點的第 3個子節點,對應 XML 元素就是第 2 個 book 元素的第3個子元素 price。,Element元素物件,Element 物件代表樹狀結構的 XML 元素節點:NodeList tagNodes=document.getElementsByTagName(book);System.out.println(tagNodes.item(i).getTagName();由於 getElementsByTagName()回傳一個由 Element 物件所組成的 NodeList,因此可以使用 getTagName()方法取得標籤名稱Element 物件還提供 getAttribute()方法取得XML 元素的指定屬性值,如下所示:tagNodes.item(i).getAttribute(code)Note:Element 也是 Node 的子類別,Text 內容節點物件,Text 物件指的為 XML 元素的文字內容。NOTE:Text 也是 Node 的子類別。,NamedNodeMap 集合物件,NamedNodeMap 集合物件是元素的屬性集合(類似 Map 的結構)。因為一個XML元素可以擁有多個屬性,且每一個屬性名稱都有一個對應的屬性值,可以配合for迴圈來取出所有屬性,如下所示:NamedNodeMap atts=tagNodes.item(i).getAttributes();for(int j=0;j atts.getLength();j+)Node att=atts.item(j);System.out.print(+-+att.getNodeName();System.out.println(/+att.getNodeValue();,練習題,請改寫 Ch10_3_1.java 使得元素的屬性輸出會直接出現在元素之後,而且屬性名稱之前多了字元,範例結果如下:,新增XML元素和屬性-建立DOM,XML DOM 物件模型除了可以存取 XML 文件的節點外,也可以更改樹狀結構例如:自行新增節點和屬性來建立新的 XML DOM 物件。我們先以建立新的 DOM 為例建立新的 XML DOM 的語法如下:DocumentBuilder db=dbf.newDocumentBuilder();Document document=db.newDocument();程式碼使用 newDocument()方法建立 XML DOM 後,就可以使用相關方法來新增根元素、子元素和屬性。如果觀念清楚的話,以下的說明也可以用來為某一已經存在的 XML 文件新增節點。(只需把 newDocument()換成 parse()並找到必要的 context node),新增XML元素和屬性-步驟一,第一步:建立新節點使用Document 物件的相關方法來建立所需的節點物件例如:在新建立的 XML DOM 新增元素,如下所示:(請注意:只是新增節點,該節點與 document 之間暫時還沒有關係)Element root=(Element)document.createElement(book);程式碼使用 createElement()方法建立 Element 元素物件 book,這就是新文件的根元素。,新增XML元素和屬性-步驟二,第二步:插入指定的位置在建立好 XML 元素的相關物件後,我們可以使用 Node 節點物件的相關方法將節點新增到樹狀結構的 XML DOM 中,相關方法的說明如下所示:appendChild(newnode):新增 newnode 節點為其最後一個子節點。insertBefore(newnode,befnode):將 newnode節點插在 befnode 節點前。例如:將 root 節點新增成為 XML DOM 的根節點,如下所示:document.appendChild(root);,新增XML元素和屬性-步驟三,第三步:新增元素的內容在元素新增內容,就是新增文字值的子節點,如下所示:Element node=(Element)document.createElement(code);Text t=(Text)document.createTextNode(P761);node.appendChild(t);root.appendChild(node);,新增XML元素和屬性-步驟四,第四步:新增元素的屬性在 XML 節點如果擁有屬性,Element 元素物件可以使用 setAttribute()方法建立屬性,如下所示:node.setAttribute(instock,Y);程式碼新增名為instock的屬性,第1個參數是屬性名稱,第2個參數是屬性值。,刪除XML元素和屬性,如果需要刪除節點或屬性,我們可以使用 Node 節點的removeChild()方法從樹狀結構刪除指定的節點,如下所示:/取得 node 的一個子節點 onechildnode.removeChild(onechild);如果想刪除屬性,則是使用 Element 元素物件的removeAttribute()方法來刪除屬性,如下所示:/取得一個 Element 節點 deldel.removeAttribute(instock);,變更 XML 元素或者屬性內容,如果需要變更節點或屬性內容,我們使用 setTextContent()方法,範例如下:修改元素內容,把 code 的 P761 改成 XXX,如下所示:Element element=document.getDocumentElement().getFirstChild();element.setTextContent(XXX);修改屬性 instock 內容:Element element=document.getDocumentElement().getFirstChild();Attr attr=elem.getAttributeNode(instock);attr.setTextContent(n);,變更 XML 元素或者屬性名稱,如果需要變更節點或屬性名稱,我們可以使用 Document 節點的 renameNode()方法,語法如下:/改變 node 的名稱為 newNamedocument.renameNode(node,new namespace,newName);如果保留原來的 namespace,把原來的名稱從 library 改成 books,如下所示:/假設取得一個 Element 節點 elementElement element=document.getDocumentElement();document.renameNode(element,element.getNamespaceURI(),“books”);,Ch10_4_4,import javax.xml.parsers.*;import org.xml.sax.*;import java.io.*;import org.w3c.dom.*;public class Ch10_4_4 static Document document;public static void main(String args)throws Exception DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();DocumentBuilder db=dbf.newDocumentBuilder();/建立新XML文件 document=db.newDocument();/建立根元素 Element root=document.createElement(book);document.appendChild(root);/新增子元素code Element node=document.createElement(code);root.appendChild(node);node.appendChild(document.createTextNode(P761);/新增子元素title node=document.createElement(title);root.appendChild(node);node.appendChild(document.createTextNode(PHP 5網頁設計範例教本);,Ch10_4_4,/新增author元素 Element newNode=document.createElement(author);root.insertBefore(newNode,root.getFirstChild();Node newText=document.createTextNode(陳會安);root.getFirstChild().appendChild(newText);/新增屬性 node=(Element)root.getFirstChild().getNextSibling();node.setAttribute(instock,Y);System.out.println(建立的XML文件:);printXML(root);/刪除author元素 root.removeChild(Element)root.getElementsByTagName(author).item(0);/刪除code屬性instock Element del=(Element)root.getFirstChild();del.removeAttribute(instock);System.out.println(刪除後的XML文件:);printXML(root);,Ch10_4_4,/顯示XML文件 private static void printXML(Node root)System.out.println(根元素:+root.getNodeName();NodeList nodes=root.getChildNodes();/取得所有的子節點 for(int i=0;i nodes.getLength();i+)/元素和文字節點 System.out.print(元素:+nodes.item(i).getNodeName();System.out.println(/+nodes.item(i).getFirstChild().getNodeValue();/顯示指定元素的屬性值 if(nodes.item(i).hasAttributes()NamedNodeMap atts=nodes.item(i).getAttributes();for(int j=0;j atts.getLength();j+)Node att=atts.item(j);System.out.print(+-+att.getNodeName();System.out.println(/+att.getNodeValue();,Ch10_4_4,/輸出 XML 文件 private static void printXML(Node root)PrintWriter out=new PrintWriter(new FileWriter(test.xml);out.println(根元素:+root.getNodeName();NodeList nodes=root.getChildNodes();for(int i=0;i nodes.getLength();i+)out.print(元素:+nodes.item(i).getNodeName();out.println(/+nodes.item(i).getFirstChild().getNodeValue();/顯示指定元素的屬性值 if(nodes.item(i).hasAttributes()NamedNodeMap atts=nodes.item(i).getAttributes();for(int j=0;j atts.getLength();j+)Node att=atts.item(j);out.print(+-+att.getNodeName();out.println(/+att.getNodeValue();out.close();,練習題,請修改 Ch10_4_1 並使其能夠產生 Books.xml 的 XML 文件。,DTD 驗證,JAXP API 1.1 版只支援 DTD 驗證,並不支援 XML Schema(1.2版之後才支援)。當XML 文件指定 DTD 檔案,在 XML 剖析器載入 XML 文件時,就可以進行XML文件的驗證。JDK 1.4 supports JAXP API 1.1JDK 1.5 supports JAXP API 1.3JDK 1.6 supports JAXP API 1.4,TestXSD,/驗證 XML Schemaimport java.io.*;import javax.xml.parsers.*;import org.w3c.dom.*;import org.xml.sax.*;public class TestXSD public static void main(String args)if(args.length!=1)System.out.println(Usage:java TestXSD myFile.xml);System.exit(-1);String xmlFile=args0;try TestXSD xmlTester=new TestXSD(xmlFile);catch(Exception e)System.out.println(e.getClass().getName()+:+e.getMessage();,TestXSD,public TestXSD(String xmlFile)throws ParserConfigurationException,SAXException,IOException DocumentBuilderFactory factory=DocumentBuilderFactory.newInstance();System.out.println(Parser名稱:+factory.getClass().getName();/預設為 false,必須是 true,因為 xsd:schema factory.setNamespaceAware(true);factory.setValidating(true);/明確告知 JAXP 所使用的 Schema 語言 factory.setAttribute(http:/http:/www.w3.org/2001/XMLSchema);/Specify our own schema-this overrides the schemaLocation in the xml file/factory.setAttribute(http:/file:./person1.xsd);DocumentBuilder builder=factory.newDocumentBuilder();builder.setErrorHandler(new SimpleErrorHandler();/parse 錯誤會引起 SAXException Document document=builder.parse(xmlFile);Node rootNode=document.getFirstChild();System.out.println(Root node:+rootNode.getNodeName();,SimpleErrorHandler,import org.xml.sax.ErrorHandler;import org.xml.sax.SAXParseException;public class SimpleErrorHandler implements ErrorHandler public void error(SAXParseException exception)System.out.println(error:+exception.getMessage();public void fatalError(SAXParseException exception)System.out.println(fatalError:+exception.getMessage();public void warning(SAXParseException exception)System.out.println(warning:+exception.getMessage();,XPath API,JDK 1.5 版之後,提供了一個非常好用的 XPath API,其 package 為 javax.xml.xpath.步驟一:把 XML 檔案依照之前的方式載入DocumentBuilderFactory domFactory=DocumentBuilderFactory.newInstance();domFactory.setNamespaceAware(true);/never forget this!DocumentBuilder builder=domFactory.newDocumentBuilder();Document doc=builder.parse(Books.xml);,XPath API,步驟二:產生 XPath 物件/載入 XPathFactoryXPathFactory factory=XPathFactory.newInstance();/利用 XPathFactory 產生 XPath 處理器XPath xpath=factory.newXPath();步驟三:產生 XPath Expression,執行結果為一個 NodeList 物件/compile XPath 敘述XPathExpression expr=pile(/book/title/text();/進行 XPath 敘述的執行,並回傳 NODESETObject

    注意事项

    本文(【教学课件】第10章XMLDOM物件模型.ppt)为本站会员(牧羊曲112)主动上传,三一办公仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知三一办公(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-2

    经营许可证:宁B2-20210002

    宁公网安备 64010402000987号

    三一办公
    收起
    展开