欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java org.w3c.dom.Document 類方法引用報錯

 更新時間:2021年08月06日 15:46:09   作者:千山牧雪  
這篇文章主要介紹了Java org.w3c.dom.Document 類方法引用報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

org.w3c.dom.Document 類方法引用報錯

The method setXmlVersion(String) is undefined for the type Document

開發(fā)時我們可能會碰到這樣的問題,它產(chǎn)生的原因是我們實(shí)際需要調(diào)用的是 JDK 環(huán)境 rt.jar 下的 org.w3c.dom.org.w3c.dom.Document ,但事實(shí)上 Eclipse 等 IDE 工具此時自動為我們調(diào)用的是 J2EE 中的 xerces\xmlParserAPIs\2.6.2\xmlParserAPIs-2.6.2.jar ,這一點(diǎn)通過 Ctrl 左鍵點(diǎn)擊 Document 類可以發(fā)現(xiàn)。

發(fā)現(xiàn)問題出在哪里就好解決了

我們需要做的是調(diào)整 Eclipse 的調(diào)用順序

項(xiàng)目右鍵 > Properties > Java Build Path > 右邊 Order and Export

把 JRE System Library 通過點(diǎn)擊 Up 按鈕放到 J2EE(Maven Dependencies) 的上面即可。

org.w3c.dom(java dom)解析XML文檔

位于org.w3c.dom操作XML會比較簡單,就是將XML看做是一顆樹,DOM就是對這顆樹的一個數(shù)據(jù)結(jié)構(gòu)的描述,但對大型XML文件效果可能會不理想

首先來了解點(diǎn)Java DOM 的 API:

1.解析器工廠類:DocumentBuilderFactory

創(chuàng)建的方法:

DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();

2.解析器:DocumentBuilder

創(chuàng)建方法:通過解析器工廠類來獲得

DocumentBuilder db = dbf.newDocumentBuilder();

3.文檔樹模型Document

創(chuàng)建方法:a.通過xml文檔 Document doc = db.parse("bean.xml"); b.將需要解析的xml文檔轉(zhuǎn)化為輸入流 InputStream is = new FileInputStream("bean.xml");

Document doc = db.parse(is); 

Document對象代表了一個XML文檔的模型樹,所有的其他Node都以一定的順序包含在Document對象之內(nèi),排列成一個樹狀結(jié)構(gòu),以后對XML文檔的所有操作都與解析器無關(guān),

直接在這個Document對象上進(jìn)行操作即可;

包含的方法:

4.節(jié)點(diǎn)列表類NodeList

NodeList代表了一個包含一個或者多個Node的列表,根據(jù)操作可以將其簡化的看做為數(shù)組

5.節(jié)點(diǎn)類Node

Node對象是DOM中最基本的對象,代表了文檔樹中的抽象節(jié)點(diǎn)。但在實(shí)際使用中很少會直接使用Node對象,而是使用Node對象的子對象Element,Attr,Text等

6.元素類Element

是Node類最主要的子對象,在元素中可以包含屬性,因而Element中有存取其屬性的方法

7.屬性類Attr

代表某個元素的屬性,雖然Attr繼承自Node接口,但因?yàn)锳ttr是包含在Element中的,但并不能將其看做是Element的子對象,因?yàn)锳ttr并不是DOM樹的一部分

基本的知識就到此結(jié)束,更加具體的大家可以參閱JDK API文檔

實(shí)戰(zhàn):

1.使用DOM來遍歷XML文檔中的全部內(nèi)容并且插入元素:

school.xml文檔:

<?xml version = "1.0" encoding = "utf-8"?>
<School>
    <Student>
        <Name>沈浪</Name>
        <Num>1006010022</Num>
        <Classes>信管2</Classes>
        <Address>浙江杭州3</Address>
        <Tel>123456</Tel>
    </Student>
    <Student>
        <Name>沈1</Name>
        <Num>1006010033</Num>
        <Classes>信管1</Classes>
        <Address>浙江杭州4</Address>
        <Tel>234567</Tel>
    </Student>
    <Student>
        <Name>沈2</Name>
        <Num>1006010044</Num>
        <Classes>生工2</Classes>
        <Address>浙江杭州1</Address>
        <Tel>345678</Tel>
    </Student>
    <Student>
        <Name>沈3</Name>
        <Num>1006010055</Num>
        <Classes>電子2</Classes>
        <Address>浙江杭州2</Address>
        <Tel>456789</Tel>
    </Student>
</School>

DomDemo.java

package xidian.sl.dom;
import java.io.FileOutputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.crimson.tree.XmlDocument;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;
public class DomDemo {
    /**
     * 遍歷xml文檔
     * */
    public static void queryXml(){
        try{
            //得到DOM解析器的工廠實(shí)例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //把要解析的xml文檔讀入DOM解析器
            Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");
            System.out.println("處理該文檔的DomImplementation對象  = "+ doc.getImplementation());
            //得到文檔名稱為Student的元素的節(jié)點(diǎn)列表
            NodeList nList = doc.getElementsByTagName("Student");
            //遍歷該集合,顯示結(jié)合中的元素及其子元素的名字
            for(int i = 0; i< nList.getLength() ; i ++){
                Element node = (Element)nList.item(i);
                System.out.println("Name: "+ node.getElementsByTagName("Name").item(0).getFirstChild().getNodeValue());
                System.out.println("Num: "+ node.getElementsByTagName("Num").item(0).getFirstChild().getNodeValue());
                System.out.println("Classes: "+ node.getElementsByTagName("Classes").item(0).getFirstChild().getNodeValue());
                System.out.println("Address: "+ node.getElementsByTagName("Address").item(0).getFirstChild().getNodeValue());
                System.out.println("Tel: "+ node.getElementsByTagName("Tel").item(0).getFirstChild().getNodeValue());
            }
            
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    /**
     * 向已存在的xml文件中插入元素
     * */
    public static void insertXml(){
        Element school = null;
        Element student = null;
        Element name = null;
        Element num = null;
        Element classes = null;
        Element address = null;
        Element tel = null;
        try{
            //得到DOM解析器的工廠實(shí)例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //把要解析的xml文檔讀入DOM解析器
            Document doc = dbBuilder.parse("src/xidian/sl/dom/school.xml");
            //得到文檔名稱為Student的元素的節(jié)點(diǎn)列表
            NodeList nList = doc.getElementsByTagName("School");
            school = (Element)nList.item(0);
            //創(chuàng)建名稱為Student的元素
            student = doc.createElement("Student");
            //設(shè)置元素Student的屬性值為231
            student.setAttribute("examId", "23");
            //創(chuàng)建名稱為Name的元素
            name = doc.createElement("Name");
            //創(chuàng)建名稱為 香香 的文本節(jié)點(diǎn)并作為子節(jié)點(diǎn)添加到name元素中
            name.appendChild(doc.createTextNode("香香"));
            //將name子元素添加到student中
            student.appendChild(name);
            /**
             * 下面的元素依次加入即可
             * */
            num = doc.createElement("Num");
            num.appendChild(doc.createTextNode("1006010066"));
            student.appendChild(num);
            
            classes = doc.createElement("Classes");
            classes.appendChild(doc.createTextNode("眼視光5"));
            student.appendChild(classes);
            
            address = doc.createElement("Address");
            address.appendChild(doc.createTextNode("浙江溫州"));
            student.appendChild(address);
            
            tel = doc.createElement("Tel");
            tel.appendChild(doc.createTextNode("123890"));
            student.appendChild(tel);
            
            //將student作為子元素添加到樹的根節(jié)點(diǎn)school
            school.appendChild(student);
            //將內(nèi)存中的文檔通過文件流生成insertSchool.xml,XmlDocument位于crison.jar下
            ((XmlDocument)doc).write(new FileOutputStream("src/xidian/sl/dom/insertSchool.xml"));
            System.out.println("成功");
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }    
    }
    public static void main(String[] args){
        //讀取
        DomDemo.queryXml();
        //插入
        DomDemo.insertXml();
    }
}

運(yùn)行后結(jié)果:

然后到目錄下查看生成的xml文件:

打開查看內(nèi)容:

上面添加元素后輸出的文件與之前的文件不是同一個文件,如果需要輸出到原文件中,那么只要將路徑改為原文間路徑即可:src/xidian/sl/dom/school.xml

2.創(chuàng)建XML過程與插入過程相似,就是Document需要創(chuàng)建

package xidian.sl.dom;
import java.io.FileOutputStream;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.apache.crimson.tree.XmlDocument;
import org.w3c.dom.Document;
import org.w3c.dom.Element;
public class CreateNewDom {
    /**
     * 創(chuàng)建xml文檔
     * */
    public static void createDom(){
        Document doc;
        Element school,student;
        Element name = null;
        Element num = null;
        Element classes = null;
        Element address = null;
        Element tel = null;
        try{
            //得到DOM解析器的工廠實(shí)例
            DocumentBuilderFactory dbFactory = DocumentBuilderFactory.newInstance();
            //從DOM工廠中獲得DOM解析器
            DocumentBuilder dbBuilder = dbFactory.newDocumentBuilder();
            //創(chuàng)建文檔樹模型對象
            doc = dbBuilder.newDocument();
            if(doc != null){
                //創(chuàng)建school元素
                school = doc.createElement("School");
                //創(chuàng)建student元素
                student = doc.createElement("Student");
                //設(shè)置元素Student的屬性值為231
                student.setAttribute("examId", "23");
                //創(chuàng)建名稱為Name的元素
                name = doc.createElement("Name");
                //創(chuàng)建名稱為 香香 的文本節(jié)點(diǎn)并作為子節(jié)點(diǎn)添加到name元素中
                name.appendChild(doc.createTextNode("香香"));
                //將name子元素添加到student中
                student.appendChild(name);
                /**
                 * 下面的元素依次加入即可
                 * */
                num = doc.createElement("Num");
                num.appendChild(doc.createTextNode("1006010066"));
                student.appendChild(num);
                
                classes = doc.createElement("Classes");
                classes.appendChild(doc.createTextNode("眼視光5"));
                student.appendChild(classes);
                
                address = doc.createElement("Address");
                address.appendChild(doc.createTextNode("浙江溫州"));
                student.appendChild(address);
                
                tel = doc.createElement("Tel");
                tel.appendChild(doc.createTextNode("123890"));
                student.appendChild(tel);
                
                //將student作為子元素添加到樹的根節(jié)點(diǎn)school
                school.appendChild(student);
                //添加到文檔樹中
                doc.appendChild(school);
                //將內(nèi)存中的文檔通過文件流生成insertSchool.xml,XmlDocument位于crison.jar下
                ((XmlDocument)doc).write(new FileOutputStream("src/xidian/sl/dom/createSchool.xml"));
                System.out.println("創(chuàng)建成功");
            }
        }catch (Exception e) {
            // TODO: handle exception
            e.printStackTrace();
        }
    }
    public static void main(String[] args) {
        CreateNewDom.createDom();
    }
}

運(yùn)行結(jié)果:

DOM的操作應(yīng)該還是非常簡單明了的,掌握了沒哦。

以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java獲取線程ID的實(shí)例

    Java獲取線程ID的實(shí)例

    以下實(shí)例演示了如何使用 getThreadId() 方法獲取線程id,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2020-10-10
  • spring @Component注解原理解析

    spring @Component注解原理解析

    這篇文章主要介紹了spring @Component注解原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-02-02
  • 新手也能看懂的SpringBoot異步編程指南(簡單易懂)

    新手也能看懂的SpringBoot異步編程指南(簡單易懂)

    這篇文章主要介紹了新手也能看懂的SpringBoot異步編程指南(簡單易懂),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Spring使用Configuration注解管理bean的方式詳解

    Spring使用Configuration注解管理bean的方式詳解

    在Spring的世界里,Configuration注解就像是一位細(xì)心的園丁,它的主要職責(zé)是在這個繁花似錦的園子里,幫助我們聲明和管理各種各樣的bean,本文給大家介紹了在Spring中如何優(yōu)雅地管理你的bean,需要的朋友可以參考下
    2024-05-05
  • 如何將Mybatis連接到ClickHouse

    如何將Mybatis連接到ClickHouse

    這篇文章主要介紹了如何將Mybatis連接到ClickHouse,幫助大家更好得理解和學(xué)習(xí)使用Mybatis,感興趣的朋友可以了解下
    2021-03-03
  • java逗號分隔String字符串及數(shù)組、集合相互轉(zhuǎn)換

    java逗號分隔String字符串及數(shù)組、集合相互轉(zhuǎn)換

    我們在日常開發(fā)時會經(jīng)常遇到將一個字符串按照逗號進(jìn)行分割,這篇文章主要給大家介紹了關(guān)于java逗號分隔String字符串及數(shù)組、集合相互轉(zhuǎn)換的相關(guān)資料,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2024-02-02
  • Java雪花算法的實(shí)現(xiàn)詳解

    Java雪花算法的實(shí)現(xiàn)詳解

    雪花算法(Snowflake)是一種分布式唯一ID生成算法,用于生成全局唯一的ID,使用雪花算法生成的ID通常是一個64位的整數(shù),可以根據(jù)需要進(jìn)行轉(zhuǎn)換和展示,在Java等編程語言中,可以使用相應(yīng)的庫或工具來生成雪花算法的ID,本文給大家介紹了Java雪花算法的實(shí)現(xiàn)
    2023-11-11
  • IDEA的Mybatis Log Plugin插件配置和使用詳解

    IDEA的Mybatis Log Plugin插件配置和使用詳解

    這篇文章主要介紹了IDEA的Mybatis Log Plugin插件配置和使用,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • Java中Map與對象之間互相轉(zhuǎn)換的幾種常用方式

    Java中Map與對象之間互相轉(zhuǎn)換的幾種常用方式

    在Java中將對象和Map相互轉(zhuǎn)換是常見的操作,可以通過不同的方式實(shí)現(xiàn)這種轉(zhuǎn)換,下面這篇文章主要給大家介紹了關(guān)于Java中Map與對象之間互相轉(zhuǎn)換的幾種常用方式,需要的朋友可以參考下
    2024-01-01
  • springboot使用Hutool的JschUtil及下載安裝步驟

    springboot使用Hutool的JschUtil及下載安裝步驟

    這篇文章主要為大家介紹了springboot使用Hutool的JschUtil的方法及下載安裝詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08

最新評論