前言

XML现已成为一种通用的数据交流方式,它的平台无关性。语言无关性。系统无关性。给数据集成与交互带来了极大的方便,对于XML的解析有四种方式:DOM生成和解析XML文档,SAX生成和解析XML文件。JDOM生成和解析XML以及dom4j生成和解析XML,本篇仅仅是简介一下dom4j的使用。

dom4j是什么?

dom4j是一个Java的XML API,事实上和。

net中的api作用同样。仅仅是再此dom4j仅仅有一个任务。就是为XML服务,解析文件的作用。

具有性能优异,功能强大和及其易使用的特点。

一个简单的开源库。在Java平台上与XML。Xpath,XSLT系统工作,使用Java集合框架,全面支持DOM。SAX,JAXP。

dom4j怎样使用?准备工作。

下载dom4j-1.6.1.jar,在MyEclipse中放置到WEB-INF\lib下,这样就能够使用其进行编程。

dom4j实例解析XML

①我们来写一个XML文件,命名为:sys-conf.xml

<config>
<db-info> <!-- 这些标签是能够随便命名 -->
<driver-name>oracle.jdbc.driver.OracleDriver</driver-name>
<url>jdbc:oracle:thin:@localhost:1521:ORAC</url>
<user-name>system</user-name>
<password>Huohuo123</password>
</db-info>
</config>

②写一个XmlConfigReader.java类。用来读取XML

XmlConfigReader构造方法仅仅运行一次,用单例模式来完毕

package com.bjpowernode.drp.util;

<span style="color:#FF0000;">import java.io.InputStream;</span>

<span style="color:#FF0000;">import org.dom4j.DocumentException;
import org.dom4j.io.SAXReader;
import org.dom4j.Document;
import org.dom4j.Element;</span> /**
* 解析sys-config.xml文件。(使用XPATH进行解析)
* @author HuoYaJing
*
*/
public class XmlConfigReader {
/*// 定义一个成员变量instance(单例模式-饿汉式,在载入的时候就实例化。提前占用系统资源)
private static XmlConfigReader instance=new XmlConfigReader();
// 私有的构造方法
private XmlConfigReader(){ }
// 公共的,静态的一个入口方法
public static XmlConfigReader getInstance()
{
return instance;
}*/  // 保存jdbc相关配置信息
private JdbcConfig jdbcConfig=new JdbcConfig();
// 懒汉式(延迟载入)
private static XmlConfigReader instance=null;
// 构造器仅仅运行一次
private XmlConfigReader(){
SAXReader reader=new SAXReader();
InputStream in=Thread.currentThread().getContextClassLoader().getResourceAsStream("sys-conf.xml"); /*获取当前线程*/ try {
Document doc=reader.read(in);
// 取得JDBC相关信息
// Element:用于描写叙述XML文档中的元素
Element driverNameElt=(Element)doc.selectObject("/config/db-info/driver-name");
Element urlElt=(Element)doc.selectObject("/config/db-info/url");
Element userNameElt=(Element)doc.selectObject("/config/db-info/user-name");
Element passwordElt=(Element)doc.selectObject("/config/db-info/password");
/*String driverName=driverNameElt.getStringValue();
String url=urlElt.getStringValue();
String userName=userNameElt.getStringValue();
String password=passwordElt.getStringValue();*/
//设置JDBC相关配置
jdbcConfig.setDriverName(driverNameElt.getStringValue());
jdbcConfig.setUrl(urlElt.getStringValue());
jdbcConfig.setUserName(userNameElt.getStringValue());
jdbcConfig.setPassword(passwordElt.getStringValue());
} catch (DocumentException e) {
// TODO: handle exception
e.printStackTrace();
}
}
// 同步keywordsyschronized,为了防止多个实例来訪问同一时候为空的情况。当然那样也就不属于单例了
public static synchronized XmlConfigReader getInstance()
{
if(instance==null)
{
// 仅仅有在使用的时候才载入。不用不载入
instance=new XmlConfigReader();
}
return instance;
}
/*返回JDBC相关配置*
*
* @return
*/
public JdbcConfig getJdbcConfig()
{
return jdbcConfig;
} public static void main(String[] args)
{
JdbcConfig jdbcConfig=XmlConfigReader.getInstance().getJdbcConfig();
/*// 方法一。一个一个的获取值出来
System.out.println(jdbcConfig.getDriverName());
System.out.println(jdbcConfig.getUrl());getDrivreName
System.out.println(jdbcConfig.getUserName());*/
System.out.println(jdbcConfig);
}
}

③单独写一个JdbcConfig.java类来完毕实体信息

package com.bjpowernode.drp.util;
/**
* JDBC配置信息
* @author HuoYaJing
*
*/
public class JdbcConfig {
private String driverName; private String url; private String userName; private String password; public String getDriverName() {
return driverName;
} public void setDriverName(String drivreName) {
this.driverName = drivreName;
} public String getUrl() {
return url;
} public void setUrl(String url) {
this.url = url;
} public String getUserName() {
return userName;
} public void setUserName(String userName) {
this.userName = userName;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public String toString(){
return this.getClass().getName()+"{driverName:"+driverName+",url:"+url+",userName:"+userName+"}"; }
}

④数据连接,处理的页面DBUtil.java

package com.bjpowernode.drp.util;

import java.sql.Connection;
import java.sql.DriverManager;
/**
* 封装数据经常使用操作
* @author HuoYaJing
*/
public class DbUtil {
/**
* 取得Connection
* @return
*/
public static Connection getConnection()
{
Connection conn=null;
try {
JdbcConfig jdbcConfig=XmlConfigReader.getInstance().getJdbcConfig();
// Class.forName("oracle.jdbc.driver.OracleDriver");
Class.forName(jdbcConfig.getDriverName());
/*String url="jdbc:oracle:thin:@localhost:1521:ORAC";
String username="system";
String password="Huohuo123";
conn=DriverManager.getConnection(url,username,password);*/
conn=DriverManager.getConnection(jdbcConfig.getUrl(),jdbcConfig.getUserName(),jdbcConfig.getPassword());
} catch (ClassNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
return conn;
} public static void main(String [] args)
{
System.out.println(DbUtil.getConnection());
}
}

这样。总体4部曲就完毕了,最后执行的效果例如以下:

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="">

我们获取到了driverName,url,以及userName的值。如图所看到的。

调试BUG:

当初步看见这个问题的时候,真的是一头误解,后来通过调试发现“in”值是为空的。如图:

其根本还是没有获取xml文件的值。

InputStream in=Thread.currentThread().getContextClassLoader().getResourceAsStream("sys-conf.xml");

     要注意文件创建的位置,解析XML。终于是读取XML文件,来获取值的,所以路径是非常重要的,否则调试半天依然会报错,默认情况是并列在src下的。所以假设想改变文件的的位置。仅仅要改动文件的读取路径即可。

遇到问题,不要气馁,一步一步调试,思考。总会雨过天晴。

--2015年8月23日00:28:18

Java -- XML解析工具dom4j的更多相关文章

  1. Java XML解析工具 dom4j介绍及使用实例

    Java XML解析工具 dom4j介绍及使用实例 dom4j介绍 dom4j的项目地址:http://sourceforge.net/projects/dom4j/?source=directory ...

  2. Java XML解析器

    使用Apache Xerces解析XML文档 一.技术概述 在用Java解析XML时候,一般都使用现成XML解析器来完成,自己编码解析是一件很棘手的问题,对程序员要求很高,一般也没有专业厂商或者开源组 ...

  3. XML概念定义以及如何定义xml文件编写约束条件java解析xml DTD XML Schema JAXP java xml解析 dom4j 解析 xpath dom sax

    本文主要涉及:xml概念描述,xml的约束文件,dtd,xsd文件的定义使用,如何在xml中引用xsd文件,如何使用java解析xml,解析xml方式dom sax,dom4j解析xml文件 XML来 ...

  4. 【Java】XML解析之DOM4J

    DOM4J介绍 dom4j是一个简单的开源库,用于处理XML. XPath和XSLT,它基于Java平台,使用Java的集合框架,全面集成了DOM,SAX和JAXP,使用需要引用dom4j.jar包 ...

  5. java xml解析方式(DOM、SAX、JDOM、DOM4J)

    XML值可扩展标记语言,是用来传输和存储数据的. XMl的特定: XMl文档必须包含根元素.该元素是所有其他元素的父元素.XML文档中的元素形成了一颗文档树,树中的每个元素都可存在子元素. 所有XML ...

  6. xml解析工具-jdom

    前言:近期接触SSH框架的时候,经常得配置一下xml文件:今天闲来没事就挖挖xml解析的原理供大伙儿分享.本文主要通过一个简单的例子解析一个xml文件.明白其中缘由之后,大家想定义自己的xml也绝非难 ...

  7. Java数据库编程及Java XML解析技术

    1.JDBC概述 A.  什么是JDBC? Java DataBase Connectivity:是一种用于执行SQL语句的Java API,它由一组用Java语言编写的类和接口组成.通过这些类和接口 ...

  8. NSXMLParser自定义的一个xml解析工具

    // // DenglXMLParser.h // #import <Foundation/Foundation.h> @interface DenglXMLParser : NSXMLP ...

  9. xml解析 使用dom4j操作xml

     使用dom4j操作xml 1 导入 dom4j,的jar包   2 指定要解析的XML文件 SAXReader sr=new SAXReader(); Document document= sr.r ...

随机推荐

  1. 开源ext2read代码走读之-在windows下怎样推断有几个硬盘设备?

    int get_ndisks() {     HANDLE hDevice;               // handle to the drive to be examined     int n ...

  2. 读配置文件能够保持顺序的 Java Properties 类

    序 前几天,公司项目中有一个需求是读取配置文件的.并且最好可以保证载入到内存中的顺序可以和配置文件里的顺序一致,可是.假设使用 jdk 中提供的 Properties 类的话,读取配置文件后.载入到内 ...

  3. 基于QMP实现对qemu虚拟机进行交互

    本文详解QMP,包含qmp.hmp.qemu-guest-agent的介绍.工作原理.配置方法.范例 小慢哥的原创文章,欢迎转载 目录 ▪ QMP介绍 ▪ QMP语法 ▪ 单独使用qemu,启用QMP ...

  4. jetty服务器数据源配置JNDI-Oracle,MySQL,SQLServer,DB2等 (转)

    下载jetty 下载jetty服务器(8.1.0.RC2),解压到任意目录下 http://dist.codehaus.org/jetty/jetty-hightide-8.1.0/jetty-hig ...

  5. ubuntu下安装VMware

    1 用apt-get命令更新系统 loginname@localhost:~$ sudo apt-get update 2 从官方网站下载Workstation11(Bundle Script) lo ...

  6. 什么是 Dropout

    为了应对神经网络很容易过拟合的问题,2014年 Hinton 提出了一个神器, **Dropout: A Simple Way to Prevent Neural Networks from Over ...

  7. Linux部署之NFS方式安装系统

    1.         让客户端从网络启动并且选择第二项   2.         选择语言   3.         选择键盘布局   4.         选择安装方式为NFS   5.       ...

  8. zabbix监控自身为监控机(server)

    Zabbix 监控主机 添加自身为被监控机 这里我的环境已经部署完毕(没有经验的小伙伴可以看我上一篇文章) 等待一会刷新如下页面 字体出现以下亮度就成功了

  9. Java web课程学习之JSP

    JSP     jsp隐式对象:JSP隐式对象是JSP容器为每个页面提供的Java对象,开发者可以直接使用它们而不用显式声明.JSP隐式对象也被称为预定义变量. jsp脚本片段 l jsp脚本片段是指 ...

  10. HDU 5918 Sequence I

    题目来源:2016 CCPC 长春站 题意:给出两个序列 a[] , b[] ,如果b1,b2....bm能够与aq,aq+p,aq+2p...aq+(m-1)p对应( q+(m-1)p<=n ...