介绍介绍DOM4J。

   据说是非常优秀非常优秀的Java XML  API(Dom4j is an easy to use, open source library for working with XML, XPath and XSLT on the Java platform using the Java Collections Framework and with full support for DOM, SAX and JAXP.)。

    关于XML文件。

   A君问了我一个问题,为什么java中XML作为配置文件,为什么不用其他的呢?像text文件等等。

   我的第一个反应是,为(喂)什么就吃什么。。。然后再问为什么。。。开始的时候模仿着做,时间长的时候思

考一些经常使用的东西的原因,就像为什么同一个公司,他的职位比我高一样。。。我们需要的是思考和学习。。。

   转回来说说我们配置文件的特点:我们在这里的配置文件需要能够存放少量的数据,并易于操作和维护。所以在

开始进行选择的时候就会综合考虑,text的特性,编码问题等等。所以综合考虑的话就会把XML作为j2ee的一个标准

而不是text作为j2ee的标准。(仅是我的理解......)

    最开始我们连接数据库的方式:

/**	 * 取得connection
* @return
*
*/
public static Connection getConnection() throws ClassNotFoundException
{
//数据库连接对象。
Connection conn = null;
try
{
//驱动名称。
Class.forName("oracle.jdbc.driver.OracleDriver");
//数据库连接字符串。
String url = "jdbc:oracle:thin:@localhost:1521:BJPOWERNODE";
//oracle数据库用户名和密码。
String username = "drp";
String password = "drp";
//连接数据库。
conn = DriverManager.getConnection(url, username, password);
}catch(ClassNotFoundException e){
//打印错误。
e.printStackTrace();
}catch(SQLException e){
//打印错误。
e.printStackTrace();
}
//返回连接对象。
return conn;
}

   进行了些许的优化

   我们把一些连接数据的配置文件放到XML文件中,很明显,我们这样做的目的,为了改变方便。从变化的角度来

预测问题,所以把最开始的配置数据放到连接数据库类的代码中,抽取出来了,我们放到了配置文件中。

   连接的配置信息,我们放到web.xml中。

<?xml version="1.0" encoding="UTF-8"?>
<config>
<db-info>
<driver-name>oracle.jdbc.driver.OracleDriver</driver-name>
<url>jdbc:oracle:thin:@localhost:1521:BJPOWERNODE</url>
<user-name>drp</user-name>
<password>drp</password>
</db-info>
</config>

   这样抽取出来的话,我们要从这个XML文件中读取一些驱动名称,连接字符串,用户名称和密码信息了。

   如果我们把读取和连接放到连接这个类(DbUtil数据库操作工具类)中的话,这个类的职责就太重,这样不利于

大型系统的扩展工作。于是,我们把读取配置文件这个工作给了专门的一个类来干这件事情,我们命名他为

XmlConfigReader ,用这个类读取XML文件。

   从网上查找关于读取XML文件的文章,源码也很多,据说有四种方式,http://developer.51cto.com/art/201106/270685.htm 在这里就不详细说明了。我们这里采用的是DOM4j的方式来读取XML文件。主要是引入dom4j相应的包和在使用过程中查看dom4j的API就可以喽。

   读取配置文件,我们读取的是字符串,驱动名称,连接字符串,用户名称和密码信息,他们是一个整体,我们函

数的返回值如果是字符串的话,再连接数据库的时候还要把这个长长的字符串分开,这样很不方便。于是我们把他们

进行了封装,我们把他们封装成为一个配置的工具类,JdbcConfig,这样我们传递一个整体就可以了。就像人是一个

整体的,我们不要把他的胳膊腿等分开传递。

   我们封装的配置文件实体类

/**
* jdbc配置信息。
* @author lovesummer
*
*/ public class JdbcConfig { //连接字符串。
private String url;
//用户名。
private String userName;
//密码。
private String password;
//驱动器的名称。
private String driverName;
public String getDriverName() {
return driverName;
} public void setDriverName(String driverName) {
this.driverName = driverName;
} 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;
} //覆盖object的toString方法。
@Override
public String toString() {
// TODO Auto-generated method stub
return this.getClass().getName() + "{driverName:" + driverName + ", url:" + url + ",userName :" + userName + "}";
} }

    我们读取配置文件的类:

package com.bjpowernode.drp.util;
import java.io.InputStream;
import javax.servlet.jsp.tagext.TryCatchFinally;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
//读取配置文件类。
/**
* 采用单例模式解析sys-config.xml文件。
* 解析sys-config.xml文件。
*@author lovesummer
*
*/
public class XmlConfigReader { //勤汉式。
//私有的静态的成员变量。
private static XmlConfigReader instance = new XmlConfigReader(); //保存jdbc相关配置信息对象。
private JdbcConfig jdbcconfig = new JdbcConfig(); //私有的构造方法。
private XmlConfigReader()
{
SAXReader reader = new SAXReader(); //拿到当前线程。
InputStream in = Thread.currentThread().getContextClassLoader().getResourceAsStream("sys-config.xml");
try {
Document doc = reader.read(in);
//取得xml中的Element。1 、取出驱动器的名字。
Element driverNameElt = (Element)doc.selectObject("/config/db-info/driver-name"); //2 、取出url字符串。
Element urlElt = (Element)doc.selectObject("/config/db-info/url");
//3、取出用户名称和密码。
Element userNameElt = (Element)doc.selectObject("/config/db-info/user-name");
Element passwordElt = (Element)doc.selectObject("/config/db-info/password"); //取得jdbc相关配置信息。
jdbcconfig.setDriverName(driverNameElt.getStringValue());
jdbcconfig.setUrl(urlElt.getStringValue());
jdbcconfig.setUserName(userNameElt.getStringValue());
jdbcconfig.setPassword(passwordElt.getStringValue()); } catch (DocumentException e) {
// 打印错误
e.printStackTrace();
} } //公共的静态的入口方法。
public static XmlConfigReader getInstance()
{
return instance;
} /**
* 返回jdbc相关配置。
* @return
*/
public JdbcConfig getJdbcConfig(){ return jdbcconfig;
}
}

    优化后我们连接数据库的类(就像改革开放前后的中国):

/**
* 封装数据库常用操作,工具类
* @author lovesummer
*
*/
public class DbUtil {
/**
* 取得connection
* @return
*
*/
public static Connection getConnection() throws ClassNotFoundException
{
Connection conn = null; try {
//新建jdbc配置类。
JdbcConfig jdbcconfig = XmlConfigReader.getInstance().getJdbcConfig();
//取出驱动器的名字。
Class.forName(jdbcconfig.getDriverName()); //取得连接对象。
conn = DriverManager.getConnection(jdbcconfig.getUrl(), jdbcconfig.getUserName(), jdbcconfig.getPassword()); } catch (ClassNotFoundException e) {
// 抛出 exception
e.printStackTrace();
}catch(SQLException e)
{
e.printStackTrace();
} return conn; } //测试。
public static void main(String[] args ) throws ClassNotFoundException{
System.out.println(DbUtil.getConnection());
} }

    优化后把每个类的职责都分工明确了,在这基础上还可以再进行优化的。在这里就不讲述了。在这过程中学习到了

代码优化的这种思维方式,装上了程序员的思想,代码就这样一步步有了灵魂........加油.....

DOM4J 读取XML配置文件进行数据库连接的更多相关文章

  1. RSS阅读器(一)——dom4j读取xml(opml)文件

    接触java不久,偶有收获,最近想做一个web版RSS阅读器来锻炼一下.手头有几个从不同版本的foxmail中导出的opml文件,大家应该都知道,opml文件就是xml格式的.那么就先从这里入手,练习 ...

  2. DOM4J读取XML文件

    最近在做DRP的项目,其中涉及到了读取配置文件,用到了DOM4J,由于是刚开始接触这种读取xml文件的技术,好奇心是难免的,于是在网上又找了一些资料,这里就结合找到的资料来谈一下读取xml文件的4中方 ...

  3. 【XML】利用Dom4j读取XML文档以及写入XML文档

    Dom4j简介 dom4j是一个Java的XML API,是jdom的升级品,用来读写XML文件的.dom4j是一个十分优秀的JavaXML API,具有性能优异.功能强大和极其易使用的特点,它的性能 ...

  4. 使用dom4j读取xml连接数据库与之单例模式

    使用dom4j读取xml ,加入jar包 dom4j-1.6.1.jar jaxen-1.1-beta-6.jar public class XmlConfigReader { //懒汉式,延迟加载 ...

  5. 【XML配置文件读取】使用jdom读取XML配置文件信息

    在项目中我们经常需要将配置信息写在配置文件中,而XML配置文件是常用的格式. 下面将介绍如何通过jdom来读取xml配置文件信息. 配置文件信息 <?xml version="1.0& ...

  6. 使用dom4j 读取XML文件

    第一次接触dom4j的时候,感觉这个东西很神秘,因为之前虽然知道XML文件吧,但从来没有用过,一直感觉XML肯定不好操作.当得知,dom4j可以很容易的操作读取XML文件时,不免有些好奇,那么,用do ...

  7. Java使用dom4j读取xml时报错:org.dom4j.DocumentException: Error on line 2 of document : Invalid byte 2 of 2-byte UTF-8 sequence. Nested exception: Invalid byte 2 of 2-byte UTF-8 sequence

    1.Java使用dom4j读取xml时报错: org.dom4j.DocumentException: Error on line 2 of document  : Invalid byte 2 of ...

  8. [drp 3]读取Xml配置文件,连接数据库

    导读:之前看一本XML的书,里面说到了对于XML的操作问题,但由于各方面的原因,一直没有总结.这次借着做项目,就总结总结对于XML文件的利用.主要是从配置数据库连接和保存数据这两方面来的.这篇博客介绍 ...

  9. dom4j读取xml

    -----记录和回顾是一个比学习更重要的环节----- 一.首先,我们需要知道xml是做什么的 1.作为软件的配置文件 2.作为数据的载体(小型的数据库) 二.xml的语法 xml文件以xml后缀名结 ...

随机推荐

  1. jquery 插件JTable使用

    http://www.jtable.org/ 下载后增加: Add these lines to the HEAD section of your HTML document: <!-- Inc ...

  2. bzoj3721

    不是说好的20s吗,怎么我19s都超时……逗我最后还得写成c++才能过……首先不难发现询问肯定是O(1)的复杂度我们先把奇数和偶数分开排序,不难发现几个性质1. 奇数的个数一定是奇数2. 奇数选取随k ...

  3. 解决Failed to connect session for conifg 故障

    服务器升级openssh之后jenkins构建报错了,报错信息如下: Failed to connet or change directory jenkins.plugins.publish_over ...

  4. MFC添加自定义消息

    由于MFC中无法通过类向导来自定义消息,所以需要手动添加,主要过程如下: 本文基于vs2008下通过线程实现数据实时更新的对话框运用程序 1. 定义消息(Resource.h文件中): 由于很多新控件 ...

  5. 汇编学习笔记(3)[bx]和loop

    本文是<汇编语言>一书的学习笔记,对应书中的4-6章. 汇编程序的执行 要想将源代码变为可执行的程序需经过编译.连接两个步骤,WIN7操作系统下需要MASM程序来进行编译连接工作.将MAS ...

  6. Binary Tree Zigzag Level Order Traversal——LeetCode

    Given a binary tree, return the zigzag level order traversal of its nodes' values. (ie, from left to ...

  7. c#反序列化

    C#序列化(转载) 2011-03-15  |  凯之风  |  转藏(2) 序列化有下列要求: A> 只序列化PUBLIC的成员变量和属性 B> 类必须有默认识构造函数 C> 如果 ...

  8. 面向GC的Java编程

    转自http://hellojava.info/?p=341 HelloJava微信公众账号网站 面向GC的Java编程 Leave a reply 这是内部一个同事(沐剑)写的文章,国外有一家专门做 ...

  9. App抓包数据包之Paros的安装及使用

    1.在应用程序开发过程中,会遇到很多网络访问问题,自己没有能力提供后台服务,这时就可以抓取网络上的数据包,获取数据接口,应用在程序中.下面介绍使用paros抓取网络数据包得步骤. 2.要使用paros ...

  10. 从客户端(content="<span class="Apple-s...")中检测到有潜在危险的 Request.Form 值。

    从客户端(content="<span class="Apple-s...")中检测到有潜在危险的 Request.Form 值. 说明: 请求验证过程检测到有潜在 ...