在BS中已经学习了关于XML的知识,但是一直对于XML的理解是“不重要”,“有没有都可以”。但是在没有xml的日子里,程序员想进行进程间数据传递,必须自己设计传输接口,里面牵涉到很多烦人的数据格式等问题,使得程序员不能专注于具体业务的解决。如今xml和各种语言对xml的支持包,把程序员解脱出来了。
了解了XML再来说说关于dom4j的知识吧。dom4j是一个Java的XML API,类似于jdom,用来读写XML文件的。dom4j是一个十分优秀的JavaXML API,具有性能优异、功能强大和极其易使用的特点,同时它也是一个开放源代码的软件,可以在SourceForge上找到它。在IBM developerWorks上面还可以找到一篇文章,对主流的Java XML API进行的性能、功能和易用性的评测,所以可以知道dom4j无论在哪个方面都是非常出色的。如今可以看到越来越多的Java软件都在使用dom4j来读写XML,特别值得一提的是连Sun的JAXM也在用dom4j。这已经是必须使用的jar包,Hibernate也用它来读写配置文件。
结合DRP中的实例来理解一下吧。
XML文件:
<span style="font-family:FangSong_GB2312;font-size:18px;"><?xml version="1.0" encoding="UTF-8"?> <config> <db-info> <driver-name>oracle.jdbc.driver.OracleDriver</driver-name> <url>jdbc:oracle:thin:@127.0.0.1:1521:ORCL</url> <user-name>sys</user-name> <password>sys</password> </db-info> </config></span>读写XML文档主要依赖于org.dom4j.io包,其中提供DOMReader和SAXReader两类不同方式,而调用方式是一样的。这就是依靠接口的好处。
代码中reader的read方法是重载的,可以通过InputStream, File, Url等不同的参数来读取,通过单例模式生成一个对象,这个对象实例化一个SAXReader,然后将xml文件加载到流当中。再通过SAXReader的read()方法将其转换成一个document对象。然后通过这个document对象取到xml文件的节点的值。
读取XML的java类:
<span style="font-family:FangSong_GB2312;font-size:18px;">package conn.lishehe.drp.util; import java.io.InputStream; //引用相应的包 import org.dom4j.Document; import org.dom4j.DocumentException; import org.dom4j.Element; import org.dom4j.io.SAXReader; public class XmlConfigReader { //懒汉式 private static XmlConfigReader instance = null; //保存jdbc相关配置信息的 private JdbcConfig jdbcConfig = new JdbcConfig(); private XmlConfigReader(){ //建立一个SAXReader对象 SAXReader reader = new SAXReader(); //通过当前线程的类加载器,获得文件的相对路径,读入缓冲输入流 InputStream in = Thread.currentThread().getContextClassLoader().getResourceAsStream("sys-config.xml"); try { //取得jdbc相关配置信息 //通过流来读取xml文件 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"); //取得jdbc相关的配置 jdbcConfig.setDriverName(driverNameElt.getStringValue()); jdbcConfig.setUrl(urlElt.getStringValue()); jdbcConfig.setUserName(userNameElt.getStringValue()); jdbcConfig.setPassword(passwordElt.getStringValue()); } catch (DocumentException e) { // TODO Auto-generated catch block e.printStackTrace(); } } 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); } } </span>
定义实体类:JdbcConfig.java
<span style="font-family:FangSong_GB2312;font-size:18px;">package conn.lishehe.drp.util; /** * Jdbc * @author 徐志鹏 * */ public class JdbcConfig { 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; } private String url; private String userName; private String password; @Override public String toString() { return this.getClass().getCanonicalName() + "{driverName:" + driverName + ", url:" + url + ", userName:" + userName + "}"; } } </span>
数据处理层:DbUtil.java
<span style="font-family:FangSong_GB2312;font-size:18px;">package conn.lishehe.drp.util; import java.sql.Connection; import java.sql.DriverManager; /** * 封装数据库常用操作 * @author 徐志鹏 */ public class DbUtil { /** * 取得Connection * @return * @throws ClassNotFoundException */ public static Connection getConnection() throws ClassNotFoundException{ Connection conn = null; try { JdbcConfig jdbcConfig = XmlConfigReader.getInstance().getJdbcConfig(); Class.forName(jdbcConfig.getDriverName()); conn = DriverManager.getConnection(jdbcConfig.getUrl(), jdbcConfig.getUserName(),jdbcConfig.getPassword()); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } return conn; } public static void main(String[] args){ try { //测试获取到相应的配置文件的信息,打出来 System.out.println(DbUtil.getConnection()); } catch (ClassNotFoundException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } </span>关于上面这些代码我还是要进行记忆和总结,其实并不难,做的多了也就慢慢懂了。大家一起加油吧!!!