DOM4J 读取XML配置文件进行数据库连接
介绍介绍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中。
<?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()); } }
优化后把每个类的职责都分工明确了,在这基础上还可以再进行优化的。在这里就不讲述了。在这过程中学习到了
代码优化的这种思维方式,装上了程序员的思想,代码就这样一步步有了灵魂........加油.....

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

最近有不少Win10系统的用户想要更改用户配置文件,但不清楚具体如何操作,本文将给大家带来Win10系统设置用户配置文件的操作方法吧!Win10如何设置用户配置文件1、首先,按下“Win+I”键打开设置界面,并点击进入到“系统”设置。2、接着,在打开的界面中,点击左侧的“关于”,再找到并点击其中的“高级系统设置”。3、然后,在弹出的窗口中,切换到“”选项栏,并点击下方“用户配

苹果公司最新发布的iOS18、iPadOS18以及macOSSequoia系统为Photos应用增添了一项重要功能,旨在帮助用户轻松恢复因各种原因丢失或损坏的照片和视频。这项新功能在Photos应用的"工具"部分引入了一个名为"已恢复"的相册,当用户设备中存在未纳入其照片库的图片或视频时,该相册将自动显示。"已恢复"相册的出现为因数据库损坏、相机应用未正确保存至照片库或第三方应用管理照片库时照片和视频丢失提供了解决方案。用户只需简单几步

如何在PHP中使用MySQLi建立数据库连接:包含MySQLi扩展(require_once)创建连接函数(functionconnect_to_db)调用连接函数($conn=connect_to_db())执行查询($result=$conn->query())关闭连接($conn->close())

PHP中处理数据库连接报错,可以使用以下步骤:使用mysqli_connect_errno()获取错误代码。使用mysqli_connect_error()获取错误消息。通过捕获并记录这些错误信息,可以轻松识别并解决数据库连接问题,确保应用程序的顺畅运行。

使用PHPXML函数处理XML数据:解析XML数据:simplexml_load_file()和simplexml_load_string()加载XML文件或字符串。访问XML数据:利用SimpleXML对象的属性和方法获取元素名称、属性值和子元素。修改XML数据:使用addChild()和addAttribute()方法添加新元素和属性。序列化XML数据:asXML()方法将SimpleXML对象转换为XML字符串。实战案例:解析产品馈送XML,提取产品信息,转换并将其存储到数据库中。

2024是AI手机的元年,越来越多的手机集成了多项ai功能,通过ai智能技术的赋能,让我们的手机使用更加高效便捷。近日,年初发布的GalaxyS24系列再度提升了其生成式AI的体验,下面下详细的功能介绍,一起来看看吧。一、生成式AI深度赋能三星GalaxyS24系列通过GalaxyAI的赋能,带来了诸多智能化应用,这些功能与SamsungOneUI6.1深度集成,让用户可以随时获得便利的智能体验,显着提升了手机的使用效率和便捷性。由GalaxyS24系列首创的即圈即搜功能是亮点之一,用户只需长按

快捷的成绩查询工具、这为学生和家长提供了更方便,随着互联网的发展,越来越多的教育机构和学校开始提供网上查成绩的服务。让您轻松掌握孩子的学业进展,本文将介绍几个常用的网上查成绩平台。一、便捷——通过网上查成绩平台可以随时随地查询孩子的考试成绩家长可以方便地随时查询孩子的考试成绩,通过在电脑或手机上登录相应的网上查成绩平台。只要有网络连接、无论是在工作中还是在外出时、家长都可以及时了解孩子的学习情况,对孩子进行针对性地辅导和帮助。二、多种功能——除了成绩查询,还提供课程表、考试安排等信息许多网上查成

本教程演示了如何使用PHP有效地处理XML文档。 XML(可扩展的标记语言)是一种用于人类可读性和机器解析的多功能文本标记语言。它通常用于数据存储
