Javaweb中使用Jdom解析xml的方法

一、前言

Jdom是什么?

Jdom是一个开源项目,基于树形结构,利用纯java的技术对XML文档实现解析,生成,序列化以及多种操作。它是直接为java编程服务,利用java语言的特性(方法重载,集合),把SAX和DOM的功能结合起来,尽可能的把原来解析xml变得简单,我们使用Jdom解析xml会是一件轻松的事情。

Jdom的优点:

1、Jdom专用于java技术,比Dom应用占用更少内存。

2、Jdom提供更加简单和逻辑性访问xml信息的基础方法

3、除xml文件外,Jdom还可以访问其他的数据源,例如可以创建类从SQL查询结果中访问数据

Jdom的构成:

Jdom由6个包构成

Element类表示XML文档的元素

org.jdom:      解析xml文件所要用到的基础类

org.jdom.adapters: 包含DOM适配的Java类

org.jdom.filter:    包含xml文档的过滤类

org.jdom.input:   包含读取XML文档的Java类

org.jdom.output: 包含输出XML文档的类

org.jdom.trans form: 包含将Jdom xml文档接口转换为其他XML文档接口的Java类

xml是什么?

xml是一种广为使用的可扩展标记语言,java中解析xml的方式有很多,最常用的像jdom、dom4j、sax等等。

Jdom包下载:http://www.jdom.org/downloads/index.html

这里笔者代码做的是使用java创建一个xml和读取一个xml,仅作为笔记介绍。

二、操作

下载jdom包,解压文件jdom-2.0.6.jar,jdom-2.0.6-javadoc.jar,将包导入到lib文件夹下。(注,如果有错误的话,将Jdom中的包全部导入)

例子1:使用jdom创建一个xml文件,名字为people.xml

新建类CareateJdom

package com.book.jdom;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.output.Format;
import org.jdom2.output.XMLOutputter;
//生成xml文件
public class CreateJdom {
public static void main(String[] args) {
//定义元素
Element people,student;
people = new Element("people");
student = new Element("student");
//设置属性
student.setAttribute("name", "张三");
student.setAttribute("salary","8000");
//设置文本
student.setText("呵呵");
//将其添加到根目录下
people.addContent(student);
//新建一个文档。
Document doc = new Document(people);
//读取格式,赋值给当前的Format
Format format = Format.getCompactFormat();
//对当前格式进行初始化
format.setEncoding("UTF-8");
//设置xml文件缩进4个空格
format.setIndent(" ");
//建一个xml输出工厂,将格式给工厂
XMLOutputter xmlout = new XMLOutputter(format);
try {
//将其写好的文本给工厂,并且建一个文件输出流,将数据输出
xmlout.output(doc, new FileOutputStream("people.xml"));
System.out.println("成功!");
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
/*运行结果:
<?xml version="1.0" encoding="UTF-8"?>
<people>
<student name="张三" salary="8000" />
</people>
* */

例子2:使用Jdom解析people.xml文件

新建Readxml类

package com.book.jdom;
import java.io.IOException;
import java.util.List;
import org.jdom2.Document;
import org.jdom2.Element;
import org.jdom2.JDOMException;
import org.jdom2.input.SAXBuilder;
//读取people.xml文档
public class Readxml {
public static void main(String[] args) {
//新建构造器解析xml
SAXBuilder sax = new SAXBuilder();
//建一个文档去接受数据
Document doc;
try {
//获取people.xml文档
doc = sax.build("people.xml");
//获得根节点
Element people = doc.getRootElement();
//获得根节点下的节点数据
List<Element> list = people.getChildren();
for(int i = 0;i<list.size();i++){
Element e = list.get(i);
//获得属性值
System.out.println("name:"+e.getAttributeValue("name")+" salary:"+e.getAttributeValue("salary"));
//获得文本值
System.out.println(e.getText());
}
} catch (JDOMException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
}
}
/*
* 运行结果:
* name:张三 salary:8000
呵呵
* */

解析xml

用jdom获取多个相同标签名的不同属性值的方法
<?xml version="1.0" encoding="UTF-8"?>
<Configuration>
    <Key Name="China">
      <Value Name="TextKey">China</Value>
      <Value Name="Enabled">true</Value>
      <Value Name="PhotoIDWidth">38PhotoIDWidth</Value>
      <Value Name="PhotoIDHeight">38</Value>
      <Key Name="Adult">
        <Value Name="CrownPercent">0.10</Value>
        <Value Name="HeadPercent">0.60AdultHeadPercent</Value>
      </Key>
      <Key Name="Child">
        <Value Name="CrownPercent">0.10</Value>
        <Value Name="HeadPercent">0.60ChildHeadPercent</Value>
      </Key>
    </Key>
    <Key Name="Australia">
      <Value Name="TextKey">Australia</Value>
      <Value Name="Enabled">true</Value>
      <Value Name="PhotoIDWidth">35PhotoIDWidth</Value>
      <Value Name="PhotoIDHeight">45</Value>
      <Key Name="Adult">
        <Value Name="CrownPercent">0.061</Value>
        <Value Name="HeadPercent">0.756"Adult"HeadPercent</Value>
      </Key>
      <Key Name="Child">
        <Value Name="CrownPercent">0.072</Value>
        <Value Name="HeadPercent">0.711ChildHeadPercent</Value>
      </Key>
    </Key>
    <Key Name="Austria">
      <Value Name="TextKey">Austria</Value>
      <Value Name="Enabled">true</Value>
      <Value Name="PhotoIDWidth">35PhotoIDWidth</Value>
      <Value Name="PhotoIDHeight">45</Value>
      <Key Name="Adult">
        <Value Name="CrownPercent">0.064</Value>
        <Value Name="HeadPercent">0.744AdultHeadPercent</Value>
      </Key>
      <Key Name="Child">
        <Value Name="CrownPercent">0.078</Value>
        <Value Name="HeadPercent">0.689ChildHeadPercent</Value>
      </Key>
    </Key>
</Configuration>
package input;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.JDOMException;
import org.jdom.input.SAXBuilder;
public class ReadXML {
  /**
   * @param args
   */
  public static void main(String[] args) throws JDOMException, IOException {
    SAXBuilder sb = new SAXBuilder();
    //构造文档对象
    Document doc = sb.build(Test.class.getClassLoader().getResourceAsStream("nation.xml"));
    //获取根元素
    Element root = doc.getRootElement();
    //定位到<Configuration> -> <Key>
    List<Element> list = root.getChildren("Key");
    List<Element> children = new ArrayList<Element>();
    List<Element> childrens = new ArrayList<Element>();
    for (int i = 0; i < list.size(); i++) {
      Element element = (Element) list.get(i);
      System.out.print(element.getAttributeValue("Name"));
      //定位到<Configuration> -> <Key> -> <Value>
      children = element.getChildren("Value");
      for(int j=0; j<children.size(); j++){
        Element elementChildren = (Element) children.get(j);
        //定位到<Configuration> -> <Key> -> <Value Name="PhotoIDWidth">
        if(elementChildren.getAttributeValue("Name").equals("PhotoIDWidth")){
          //获取<Configuration> -> <Key> -> <Value Name="PhotoIDWidth"> 属性值
          System.out.print("<--------->"+elementChildren.getAttributeValue("Name"));
          //获取<Configuration> -> <Key> -> <Value Name="PhotoIDWidth"> 标签里内容
          System.out.print(","+elementChildren.getText());
        }
      }
      children.clear();
      //定位到<Configuration> -> <Key> -> <Key>
      children = element.getChildren("Key");
      for(int j=0; j<children.size(); j++){
        Element elementChildren = (Element)children.get(j);
        //定位到<Configuration> -> <Key> -> <Key Name="Child">
        if(elementChildren.getAttributeValue("Name").equals("Child")){
          //定位到<Configuration> -> <Key> -> <Key Name="Child"> -> <Value>
          childrens = elementChildren.getChildren("Value");
          for(int k=0; k<childrens.size(); k++){
            Element elementChildrens = (Element)childrens.get(k);
            //定位到<Configuration> -> <Key> -> <Key Name="Child"> -> <Value Name="HeadPercent">
            if(elementChildrens.getAttributeValue("Name").equals("HeadPercent")){
              System.out.println("<--------->"+elementChildrens.getText());
            }
          }
        }
      }
    }
  }
}
打印结果:
China<--------->PhotoIDWidth,38PhotoIDWidth<--------->0.60ChildHeadPercent
Australia<--------->PhotoIDWidth,35PhotoIDWidth<--------->0.711ChildHeadPercent
Austria<--------->PhotoIDWidth,35PhotoIDWidth<--------->0.689ChildHeadPercent

以上所述是小编给大家介绍的Javaweb中使用Jdom解析xml的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

(0)

相关推荐

  • Java使用Jdom读取xml解析实例

    本文实例讲述了Java使用Jdom读取xml解析.分享给大家供大家参考,具体如下: package com.yanek.demo.xml.test; import java.io.File; import java.io.IOException; import java.util.Iterator; import java.util.List; import org.jdom.Document; import org.jdom.Element; import org.jdom.JDOMExcep

  • Java全面解析XML格式串(JDOM解析)

    Java全面解析XML格式串(JDOM解析) import java.io.IOException; import java.io.StringReader; import java.util.List; import org.jdom.Document; import org.jdom.Element; import org.jdom.JDOMException; import org.jdom.Namespace; import org.jdom.input.SAXBuilder; impo

  • java解析xml之jdom解析xml示例分享

    复制代码 代码如下: package com.test; import java.io.File;import java.util.ArrayList;import java.util.List; import org.jdom.Document;import org.jdom.Element;import org.jdom.input.SAXBuilder; public class JdomXML { public static void main(String[] args) {     

  • java 使用JDOM解析xml文件

    JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析.生成.序列化以及多种操作.JDOM直接为JAVA编程服务.它利用更为强有力的JAVA语言的诸多特性(方法重载.集合概念以及映射),把SAX和DOM的功能有效地结合起来.JDOM的官方地址:http://www.jdom.org/1.首先新建一个接口和2个类,为后续做准备[Moveable.java] 复制代码 代码如下: package com.njupt.zhb.test;public interface Mov

  • Java中JDom解析XML_动力节点Java学院整理

    一.前言 JDOM是Breet Mclaughlin和Jason Hunter两大Java高手的创作成果,2000年初,JDOM作为一个开放源代码项目正式开始研发.JDOM是一种解析XML的Java工具包. DOM适合于当今流行的各种语言,包括Java,JavaScripte,VB,VBScript,Perl,C,C++等.它了为HTML和XML文档提供了一个可应用于不同平台的编程接口.W3C DOM的最新信息可从http://www.w3.org/TR2001/WD-DOM-Lever-3-C

  • Javaweb中使用Jdom解析xml的方法

    一.前言 Jdom是什么? Jdom是一个开源项目,基于树形结构,利用纯java的技术对XML文档实现解析,生成,序列化以及多种操作.它是直接为java编程服务,利用java语言的特性(方法重载,集合),把SAX和DOM的功能结合起来,尽可能的把原来解析xml变得简单,我们使用Jdom解析xml会是一件轻松的事情. Jdom的优点: 1.Jdom专用于java技术,比Dom应用占用更少内存. 2.Jdom提供更加简单和逻辑性访问xml信息的基础方法 3.除xml文件外,Jdom还可以访问其他的数

  • JAVA中4种解析XML文件的方法

    XML是一种通用的数据交换格式,它的平台无关性.语言无关性.系统无关性.给数据集成与交互带来了极大的方便.XML在不同的语言环境中解析方式都是一样的,只不过实现的语法不同而已. XML的解析方式分为四种: 1.DOM解析: 2.SAX解析: 3.JDOM解析: 4.DOM4J解析. 其中前两种属于基础方法,是官方提供的平台无关的解析方式:后两种属于扩展方法,它们是在基础的方法上扩展出来的,只适用于java平台. 针对以下XML文件,会对四种方式进行详细描述: <?xml version="

  • java中使用sax解析xml的解决方法

    在java中,原生解析xml文档的方式有两种,分别是:Dom解析和Sax解析 Dom解析功能强大,可增删改查,操作时会将xml文档以文档对象的方式读取到内存中,因此适用于小文档 Sax解析是从头到尾逐行逐个元素读取内容,修改较为不便,但适用于只读的大文档 本文主要讲解Sax解析,其余放在后面 Sax采用事件驱动的方式解析文档.简单点说,如同在电影院看电影一样,从头到尾看一遍就完了,不能回退(Dom可来来回回读取) 在看电影的过程中,每遇到一个情节,一段泪水,一次擦肩,你都会调动大脑和神经去接收或

  • java中使用dom4j解析XML文件的方法教程

    前言 dom4j是一个java的XML api,性能优异.功能强大.易于使用.以前听说过来解析xml文件的几种标准方式:但是从来的没有应用过来,所以可以在google中搜索dmo4j解析xml文件的方式,学习一下dom4j解析xml的具体操作.下面话不多说了,来一起看看详细的介绍吧 官网下载Dom4j地址:https://dom4j.github.io/ 注意:使用Dom4j开发,需下载dom4j相应的jar文件 题目:后台利用dom4j解析student.xml文件,并返回List<Stude

  • Android基于Pull方式解析xml的方法详解

    本文实例讲述了Android基于Pull方式解析xml的方法.分享给大家供大家参考,具体如下: Pull解析和Sax解析很相似,都是轻量级的解析,在Android的内核中已经嵌入了Pull,所以我们不需要再添加第三方jar包来支持Pull. Pull解析和Sax解析不一样的地方有: (1)pull读取xml文件后触发相应的事件调用方法返回的是数字 (2)pull可以在程序中控制想解析到哪里就可以停止解析. 来看看实例: book.xml如下: <?xml version="1.0"

  • javaweb中静态文件的常用处理方法汇总

    本文实例汇总了javaweb中静态文件的常用处理方法,在Javaweb程序开发中很有实用价值,具体方法汇总如下: 方法一:激活Tomcat的defaultServlet来处理静态文件 在web.xml中添加: <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>*.jpg</url-pattern> </servlet-mapping> <ser

  • PHP使用xpath解析XML的方法详解

    本文实例讲述了PHP使用xpath解析XML的方法.分享给大家供大家参考,具体如下: XML文件在PHP网站开发的轻量级应用中使用非常广泛,而PHP解析和读取XML文件的方式有很多种,比如JS DOM.SimpleXml.Xpath等方式解析XML文件,今天来讲讲在PHP中使用Xpath解析XML的实例,同时通过Xpath解析XML的实例来介绍部分基础的Xpath语法. Xpath是什么? Xapth主要用来在XML文档中查询信息的工具,通过使用路径表达式可以解析XML文件,读取XML文件中的数

  • Python在字符串中处理html和xml的方法

    问题 你想将HTML或者XML实体如 &entity; 或 &#code; 替换为对应的文本. 再者,你需要转换文本中特定的字符(比如<, >, 或 &). 解决方案 如果你想替换文本字符串中的 '<' 或者 '>' ,使用 html.escape() 函数可以很容易的完成.比如: >>> s = 'Elements are written as "<tag>text</tag>".' >&

  • 使用BeautifulSoup4解析XML的方法小结

    Beautiful Soup 是一个用来从HTML或XML文件中提取数据的Python库,它利用大家所喜欢的解析器提供了许多惯用方法用来对文档树进行导航.查找和修改. 帮助文档英文版:https://www.crummy.com/software/BeautifulSoup/bs4/doc/ 帮助文档中文版:https://www.crummy.com/software/BeautifulSoup/bs4/doc.zh/ 入门示例 以下是电影<爱丽丝梦游仙境>中的一段HTML内容: 我们以此为

  • JQuery解析XML的方法小结

    本文实例总结了JQuery解析XML的方法.分享给大家供大家参考,具体如下: 用JavaScript解析XML数据是常见的编程任务,JavaScript能做的,JQuery当然也能做.下面我们来总结几个使用JQuery解析XML的例子. 第一种方案: <script type="text/javascript"> $(document).ready(function() { $.ajax({ url: 'http://localhost/cgi/test.xml', dat

随机推荐