java读取xml,获取conn对象

package cn.com.burgeon.util;

import java.io.IOException;
import java.sql.Connection;
import java.sql.DriverManager;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import org.apache.log4j.Logger;
import org.jdom2.Element;
import org.jdom2.JDOMException;

public class ConnUtil {

 private static ConnUtil cu = null;

 public static ConnUtil getConnUtil() {
  if (cu == null) {
   cu = new ConnUtil();
  }
  return cu;
 }

 Logger logger = Logger.getLogger(ConnUtil.class.getName());

 public Connection getConnection(String xmlDbConf) {
  Map<String, String> map = null;
  try {
   map = getDatasourceXml(xmlDbConf);
  } catch (Exception e) {
   logger.error("读取wepos.properties文件失败\n" + e.getMessage());
  }
  Connection conn = null;
  try {

   Class.forName(map.get("driverclass"));
   conn = DriverManager.getConnection(map.get("connectionurl"), map
     .get("username"), map.get("password"));
  } catch (Exception e) {
   logger.error("连接数据库失败\n" + e.getMessage());
  }
  return conn;
 }

 /*
  * 读取连接数据库的配置文件 liferay-ds.xml
  */
 public static Map<String, String> getDatasourceXml(String xmlFile)
   throws JDOMException, IOException {
  Map<String, String> map = new HashMap<String, String>();
  org.jdom2.input.SAXBuilder sb = new org.jdom2.input.SAXBuilder();
  org.jdom2.Document doc = sb.build(new java.io.File(xmlFile)); // 改这个路径
  org.jdom2.Element root = doc.getRootElement(); // 根节点
  List<Element> childList = root.getChildren();

  String connectionurl = childList.get(1).getChildText("connection-url"); // 根节点之下的子节点class_name的内容
  String driverclass = childList.get(1).getChildText("driver-class");
  String username = childList.get(1).getChildText("user-name") == null ? "neands3"
    : childList.get(1).getChildText("user-name");
  String password = childList.get(1).getChildText("password") == null ? "abc123"
    : childList.get(1).getChildText("password");
  map.put("connectionurl", connectionurl);
  map.put("driverclass", driverclass);
  map.put("username", username);
  map.put("password", password);
  return map;
 }

}

你可能感兴趣的:(java读取xml,获取conn对象)