热门标签 | HotTags
当前位置:  开发笔记 > 数据库 > 正文

DOM4J读取XML配置文件进行数据库连接

介绍介绍DOM4J。据说是非常优秀非常优秀的JavaXMLAPI(Dom4jisaneasytouse,opensourcelibraryforworkingwithXML,XPathandXSLTontheJavaplatformusingtheJavaCollectionsFrameworkandwithfullsupportforDOM,SAXandJAXP.

介绍介绍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.

介绍介绍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中。



	
		oracle.jdbc.driver.OracleDriver
		jdbc:oracle:thin:@localhost:1521:BJPOWERNODE
		drp
		drp
	


这样抽取出来的话,我们要从这个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());
	}

}


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

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

推荐阅读
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 利用存储过程构建年度日历表的详细指南
    本文将介绍如何使用SQL存储过程创建一个完整的年度日历表。通过实例演示,帮助读者掌握存储过程的应用技巧,并提供详细的代码解析和执行步骤。 ... [详细]
  • SQLite 动态创建多个表的需求在网络上有不少讨论,但很少有详细的解决方案。本文将介绍如何在 Qt 环境中使用 QString 类轻松实现 SQLite 表的动态创建,并提供详细的步骤和示例代码。 ... [详细]
  • 程序员妻子吐槽:丈夫北漂8年终薪3万,存款情况令人意外
    一位程序员的妻子在网上分享了她丈夫在北京工作八年的经历,月薪仅3万元,存款情况却出乎意料。本文探讨了高学历人才在大城市的职场现状及生活压力。 ... [详细]
  • 本文探讨了如何像程序员一样思考,强调了将复杂问题分解为更小模块的重要性,并讨论了如何通过妥善管理和复用已有代码来提高编程效率。 ... [详细]
  • 深入理解C++中的KMP算法:高效字符串匹配的利器
    本文详细介绍C++中实现KMP算法的方法,探讨其在字符串匹配问题上的优势。通过对比暴力匹配(BF)算法,展示KMP算法如何利用前缀表优化匹配过程,显著提升效率。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细介绍了如何在 Linux 平台上安装和配置 PostgreSQL 数据库。通过访问官方资源并遵循特定的操作步骤,用户可以在不同发行版(如 Ubuntu 和 Red Hat)上顺利完成 PostgreSQL 的安装。 ... [详细]
  • 如何在PostgreSQL中查看数据表
    本文将指导您使用pgAdmin工具连接到PostgreSQL数据库,并展示如何浏览和查找其中的数据表。通过简单的步骤,您可以轻松访问所需的表结构和数据。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 在使用SQL Server进行动态SQL查询时,如果遇到LIKE语句无法正确返回预期结果的情况,通常是因为参数传递方式不当。本文将详细探讨这一问题,并提供解决方案及相关的技术背景。 ... [详细]
  • 本文介绍如何通过创建替代插入触发器,使对视图的插入操作能够正确更新相关的基本表。涉及的表包括:飞机(Aircraft)、员工(Employee)和认证(Certification)。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 精选30本C# ASP.NET SQL中文PDF电子书合集
    欢迎订阅我们的技术博客,获取更多关于C#、ASP.NET和SQL的最新资讯和资源。 ... [详细]
author-avatar
sanesTT
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有