java 使用JDOM解析xml文件_java

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

复制代码 代码如下:

package com.njupt.zhb.test;
public interface Moveable {
 void run();
}

[Plane.java]

复制代码 代码如下:

package com.njupt.zhb.test;
public class Plane implements Moveable {
 @Override
 public void run() {
  // TODO Auto-generated method stub
  System.out.println("飞机在翱翔.....");
 }
}

[Train.java]

复制代码 代码如下:

package com.njupt.zhb.test;
public class Train implements Moveable{
 @Override
 public void run() {
  System.out.println("火车在飞奔....");
 }

}

2.新建一个接口,主程序可以调用getBean方法,获得相应的对象。

复制代码 代码如下:

package com.njupt.zhb.test;
public interface BeanFactory {
 Object getBean(String id);
}

3.需要解析的xml文件如下:

复制代码 代码如下:

<?xml version="1.0" encoding="UTF-8"?>
<beans>
 <bean
     id="train"
     class="com.njupt.zhb.test.Train">
 </bean>
 <bean
     id="plane"
     class="com.njupt.zhb.test.Plane">
 </bean>
</beans>

4.解析文件的主类,实现了BeanFactory接口。

复制代码 代码如下:

package com.njupt.zhb.test;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.jdom.Document;
import org.jdom.Element;
import org.jdom.input.SAXBuilder;
import org.jdom.xpath.XPath;
public class ClassPathXmlApplicationContext implements BeanFactory {
 private Map<String, Object> mapContainer = new HashMap<String, Object>();//用于存放解析出来的id和对象
 public ClassPathXmlApplicationContext(String fileName) throws Exception {
  SAXBuilder sb = new SAXBuilder();
  Document doc = sb.build(this.getClass().getClassLoader()
    .getResourceAsStream(fileName));
  Element root = doc.getRootElement();
  List list = XPath.selectNodes(root, "/beans/bean");//获得此节点下的所有值
  System.out.println(list.size());
  for (int i = 0; i < list.size(); i++) {
   Element bean = (Element) list.get(i);
   String id = bean.getAttributeValue("id");//获得id对应的值
   String clazz = bean.getAttributeValue("class");//获得class对应的值
   Object o = Class.forName(clazz).newInstance();//Java反射机制,根据类名生成对象
   mapContainer.put(id, o);//保存到map中
   System.out.println(id + " " + clazz);
  }
 }
 @Override
 public Object getBean(String id) {
  return mapContainer.get(id);
 }
}

5.主程序TestMain调用。

复制代码 代码如下:

package com.njupt.zhb.test;
public class TestMain {
 public static void main(String[] args) throws Exception {
  BeanFactory f = new ClassPathXmlApplicationContext(
    "com/njupt/zhb/test/sample.xml");
  Object obj1 = f.getBean("train");//获得标签为train的对象
  Moveable m1 = (Moveable)obj1;//接口调用子类
  m1.run();
  // //----------------------
  Object obj2 = f.getBean("plane");
  Moveable m2 = (Moveable) obj2;
  m2.run();

 }
}

实验结果:

复制代码 代码如下:

2
train com.njupt.zhb.test.Train
plane com.njupt.zhb.test.Plane
火车在飞奔....
飞机在翱翔.....

点击下载源代码

时间: 2024-10-22 21:33:30

java 使用JDOM解析xml文件_java的相关文章

java 使用JDOM解析xml文件

java中如何使用JDOM解析xml文件呢?以下小编就用实例为大家详细的介绍一下.需要的朋友可以参考下   JDOM是一个开源项目,它基于树型结构,利用纯JAVA的技术对XML文档实现解析.生成.序列化以及多种操作.JDOM直接为JAVA编程服务.它利用更为强有力的JAVA语言的诸多特性(方法重载.集合概念以及映射),把SAX和DOM的功能有效地结合起来. JDOM的官方地址:http://www.jdom.org/1.首先新建一个接口和2个类,为后续做准备[Moveable.java] 复制代

急急!为什么Applet中运用JDOM解析XML文件时,构造文档时失败啊

问题描述 为什么Applet中运用JDOM解析XML文件时,构造文档时失败啊SAXBuildersb=newSAXBuilder();Documentdoc=sb.build("E:/sample.xml");在main()程序中就不会有这样的问题,是不是安全问题请各路大侠帮忙了,谢啦!!!

为JDOM解析XML文件成Document加速

我们用 JDOM 解析 XML 最简单的代码莫过于以下两行代码,不过为了测试我们在其前后加上记录执行时间的代码: long start = System.currentTimeMillis(); SAXBuilder builder = new SAXBuilder(); Document document = builder.build("struts-config.xml"); System.out.println("耗时:" + (System.current

深入浅出如何解析xml文件---下篇

    在上篇博文中,小编主要介绍xml的两种解析方式,分别是dom4j和dom,今天这篇博文,小编主要来简单介绍一下xml的其她两种解析方式sax和jdom.     sax解析xml文件     sax,全称是Simple API for XML ,即是一种接口,也是一种软件包,她也是一种xml解析的替代方法,sax不同于dom解析,她逐行扫描文档,一边扫描一边解析,由于应用程序只是在读取数据时检查数据,因为不需要将数据存储在内存中,这对于大型文档的解析是个巨大优势.     sax这种处理

java如何解析/读取xml文件_java

本文实例为大家分享了java解析/读取xml文件的方法,供大家参考,具体内容如下 XML文件 <?xml version="1.0"?> <students> <student> <name>John</name> <grade>B</grade> <age>12</age> </student> <student> <name>Mary<

java读取解析xml文件实例_java

读取本地的xml文件,通过DOM进行解析,DOM解析的特点就是把整个xml文件装载入内存中,形成一颗DOM树形结构,树结构是方便遍历和和操纵. DOM解析的特性就是读取xml文件转换为 dom树形结构,通过节点进行遍历. 这是W3c关于节点的概念 如果xml中包含有大量的数据,由于dom一次性把xml装入内存中的特性,所以dom不适合于包含大量数据的xml解析.当包含有大量xml的时候,用SAX进行解析比较节省内存. 下面是一个运用DOM进行解析xml文件的例子: xml文件结构如下: <?xm

java dom4j解析xml文件代码实例分享_java

解析xml文件有两种方式,一种是利用Dom去解析,这种方式写起代码比较麻烦,对于刚入手的程序员来说比较容易出问题:第二种就是使用Dom4j包去解析在要使用Dom4j包的时候,肯定要先引入包 复制代码 代码如下: import java.io.File;import java.io.FileWriter;import java.io.IOException;import java.io.Writer;import java.util.Iterator; import org.dom4j.Docum

jsp解析xml文档之使用 JDOM 读取XML文件

jsp教程解析xml文档之使用 JDOM 读取XML文件 xml文件: <?xml version="1.0" encoding="GB2312"?> <RESULT>   <VALUE>        <NO>A1234</NO>        <ADDR>四川省XX县XX镇XX路X段XX号</ADDR>   </VALUE>   <VALUE>      

在Android系统中解析XML文件的方法_java

前言    在学习Android的Framework层源码时,Android大量的使用XmlPullParser来解析xml文件的源码.因此,这里也顺道介绍一下XmlPullParser的使用. XML    XML(eXtensible Markup Language)中文名为可扩展标记语言.标记指计算机所能理解的信息符号,通过此种标记,计算机之间可以处理包含各种信息的文章等.用途    XML设计用了传送及携带数据信息,不用了表现或展示数据,HTML语言则用了表现数据,所以XML用途的焦点是