java 使用JDOM解析xml文件

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 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
火车在飞奔....
飞机在翱翔.....

时间: 2025-01-02 11:31:23

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

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 Mov

急急!为什么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这种处理

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>      

java 解析xml文件-在JAVA中解析XML文件时遇上难题,向各位大虾求助。

问题描述 在JAVA中解析XML文件时遇上难题,向各位大虾求助. 在服务器进程中编写登录时出现以下错误提示: Exception in thread "Thread-0" java.lang.ClassCastException: com.sun.org.apache.xerces.internal.dom.DeferredDocumentImpl cannot be cast to javax.swing.text.Document at server.ServerThread.Lo

java解析xml文件中数据,数据之间用0x2588做分隔符,怎么解析

问题描述 java解析xml文件中数据,数据之间用0x2588做分隔符,怎么解析 java解析xml文件中数据,数据之间用0x2588做分隔符,0x2588做分隔符分隔符问题,这个0x2588的分隔符怎么处理 解决方案 xml字符串.split((char)(0x2588)) 解决方案二: 我试试 ,谢谢好心人,谢谢你抽出时间 谢谢

java解析xml文件多个线程同时访问时内存溢出

问题描述 java解析xml文件多个线程同时访问时内存溢出,代码如下:解析的xml文件大小大概2M-10M,该怎么解决呢? String sourceFile = ConfigReader.get("data.store.path") + article.getSourceFile();org.dom4j.Document document = null;FileInputStream fin = null;try {fin = new FileInputStream(new File

java读取解析xml文件实例_java

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