日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

java 讀取xml

 青苔IT 2021-06-24

1.DB.java

 package com.bn.util;
 import java.sql.Connection;
 import java.sql.DriverManager;
 import java.sql.PreparedStatement;
 import java.sql.ResultSet;
 import java.sql.SQLException;
 import java.sql.Statement;
 import java.util.Iterator;
 import java.util.Properties;
 import org.dom4j.Document;
 import org.dom4j.DocumentException;
 import org.dom4j.Element;
 import org.dom4j.io.SAXReader;
 public class DB {
 private static String dbServer;
 private static String dbName;
 private static String dbUser;
 private static String dbPwd;
 
 public void readXML(){
     
     SAXReader sr = new SAXReader();//獲取讀取xml的對(duì)象。
    Document doc = null;
     String path1 = String.valueOf(Thread.currentThread().getContextClassLoader().getResource(""));
     //System.out.println(path1);
     path1 = path1 + "../DB.xml";
     //System.out.println(path1);
   try {
    doc = sr.read(path1);
   } catch (DocumentException e) {
    // TODO Auto-generated catch block
    e.printStackTrace();
   }//得到xml所在位置。然后開(kāi)始讀取。并將數(shù)據(jù)放入doc中
    Element el_root = doc.getRootElement();//向外取數(shù)據(jù),獲取xml的根節(jié)點(diǎn)。
    Iterator it = el_root.elementIterator();//從根節(jié)點(diǎn)下依次遍歷,獲取根節(jié)點(diǎn)下所有子節(jié)點(diǎn)
    
     while(it.hasNext()){//遍歷該子節(jié)點(diǎn)
     
      Object o = it.next();//再獲取該子節(jié)點(diǎn)下的子節(jié)點(diǎn)
     Element el_row = (Element)o;
      String s = el_row.getText();
      Iterator it_row = el_row.elementIterator();
      int i =1;
      while(it_row.hasNext()){//遍歷節(jié)點(diǎn)
      Element el_ename = (Element)it_row.next();//獲取該節(jié)點(diǎn)下的所有數(shù)據(jù)。
   
       if(i == 1){
        this.setDbServer(el_ename.getText());
        //System.out.println(this.getDbServer());
        //dbServer = el_ename.getText();
       }
       if(i == 2){
        this.setDbName(el_ename.getText());
         // System.out.println(this.getDbName());
        //dbName = el_ename.getText();
       }
       if(i == 3){
        this.setDbUser(el_ename.getText());
         // System.out.println(this.getDbUser());
        //dbUser = el_ename.getText();
       }
       if(i == 4){
        this.setDbPwd(el_ename.getText());
         // System.out.println(this.getDbPwd());
        //dbPwd = el_ename.getText();
       }
      // System.out.println(i);
       i++;
       //System.out.println(el_ename.getText());
      }
      //System.out.println(o);
     }
     
    }
 static {
   DB dbxml = new DB();
   dbxml.readXML();
   
   try {
    Class.forName("com.mysql.jdbc.Driver");
   } catch (ClassNotFoundException e) {
    e.printStackTrace();
   }
 }

 public static Connection createConn(){
   DB dbxml = new DB();
   //String name = dbxml.dbName;
   //System.out.println(name);
   //System.out.println(dbxml.getDbServer() + dbxml.getDbName() + dbxml.getDbUser() + dbxml.getDbPwd());
   Connection conn = null;
   try {
    conn = DriverManager.getConnection("jdbc:mysql://"+ dbxml.getDbServer() +":3306/"+ dbxml.getDbName() +"?user="+ dbxml.getDbUser() +"&password="+ dbxml.getDbPwd());
    //conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/bnss?user=root&password=root");
   } catch (SQLException e) {
    e.printStackTrace();
   }
   return conn;
 }

 public static PreparedStatement createPstmt(Connection conn, String sql){
   PreparedStatement pstmt = null;
   try {
    pstmt = conn.prepareStatement(sql);
   } catch (SQLException e) {
    e.printStackTrace();
   }
   return pstmt;
 }

 public static void close(Connection conn){
   if(conn == null)return;
   try {
    conn.close();
    conn = null;
   } catch (SQLException e) {
    e.printStackTrace();
   }
 }

 public static void close(Statement stmt){
   try {
    stmt.close();
    stmt = null;
   } catch (SQLException e) {
    e.printStackTrace();
   }
 }

 public static void close(ResultSet rs){
   try {
    rs.close();
    rs = null;
   } catch (SQLException e) {
    e.printStackTrace();
   }
 }
 public String getDbName() {
   return dbName;
 }
 public void setDbName(String dbName) {
   this.dbName = dbName;
 }
 public String getDbServer() {
   return dbServer;
 }
 public String getDbUser() {
   return dbUser;
 }
 public String getDbPwd() {
   return dbPwd;
 }
 public void setDbServer(String dbServer) {
   this.dbServer = dbServer;
 }
 public void setDbUser(String dbUser) {
   this.dbUser = dbUser;
 }
 public void setDbPwd(String dbPwd) {
   this.dbPwd = dbPwd;
 }
 }

2.ParseXML.java

 package com.bn.util;
 import java.util.Properties;
 import javax.xml.parsers.ParserConfigurationException;
 import javax.xml.parsers.SAXParser;
 import javax.xml.parsers.SAXParserFactory;
 import org.xml.sax.SAXException;
 import java.net.URL;
 
 //java項(xiàng)目www.fhadmin.org
 public class ParseXML{
     //定義一個(gè)Properties 用來(lái)存放 dbhost dbuser dbpassword的值
    private Properties props;
     //這里的props
     public Properties getProps() {
         return this.props;
     }
     public void parse(String filename) {
         //將我們的解析器對(duì)象化
        ConfigParser handler = new ConfigParser();
         //獲取SAX工廠(chǎng)對(duì)象
        SAXParserFactory factory = SAXParserFactory.newInstance();
         factory.setNamespaceAware(false);
         factory.setValidating(false);
         //獲取SAX解析
        SAXParser parser=null;
         try {
             parser = factory.newSAXParser();
         } catch (Exception e1) {            
             e1.printStackTrace();
         }        
         URL confURL = null;
         //得到配置文件myenv.xml所在目錄. tomcat中是在WEB-INF/classes
         //下例中BeansConstants是用來(lái)存放xml文件中配置信息的類(lèi),可以自己代替或定義
        try{
             confURL = ParseXML.class.getClassLoader().getResource(filename);
 //只需要將我們所需要的XML文件名字輸入進(jìn)去就可以了!
        }catch(Exception e){
             System.out.print(e.toString());
         }
         try
         {    //將解析器和解析對(duì)象myenv.xml聯(lián)系起來(lái),開(kāi)始解析
            parser.parse(confURL.toString(), handler);
             //獲取解析成功后的屬性 以后 我們其他應(yīng)用程序只要調(diào)用本程序的props就可以提取出屬性名稱(chēng)和值了
            props = handler.getProps();
         }catch(Exception e){
             System.out.println(e.toString());
         }finally{
             factory=null;
             parser=null;
             handler=null;
         }
     }
 }

3.ConfigParser.java

package com.bn.util;
 import org.xml.sax.Attributes;
 import org.xml.sax.helpers.DefaultHandler;
 import org.xml.sax.SAXException;
 import java.util.Properties;

//使用DefaultHandler的好處 是 不必陳列出所有方法,
//java項(xiàng)目www.fhadmin.org
public class ConfigParser extends DefaultHandler {
     ////定義一個(gè)Properties 用來(lái)存放 dbhost dbuser dbpassword的值
    private Properties props;
     private String currentSet;
     private String currentName;
     private StringBuffer currentValue = new StringBuffer();
     //構(gòu)建器初始化props
     public ConfigParser() {
         this.props = new Properties();
     }
     public Properties getProps() {
         return this.props;
     }
     //定義開(kāi)始解析元素的方法. 這里是將<xxx>中的名稱(chēng)xxx提取出來(lái).
     public void startElement(String uri, String localName, String qName, Attributes attributes)throws SAXException {
         currentValue.delete(0, currentValue.length());
         this.currentName =qName;
     }
     //這里是將<xxx></xxx>之間的值加入到currentValue
     public void characters(char[] ch, int start, int length) throws SAXException {
         currentValue.append(ch, start, length);
     }
     //在遇到</xxx>結(jié)束后,將之前的名稱(chēng)和值一一對(duì)應(yīng)保存在props中
    public void endElement(String uri, String localName, String qName) throws SAXException {
         props.put(qName.toLowerCase(), currentValue.toString().trim());
     }
 }

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀(guān)點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶(hù) 評(píng)論公約

    類(lèi)似文章 更多