zoukankan      html  css  js  c++  java
  • mysql jdbc

    天要将以前一个项目的数据连接改成从properties文件中配置。找了好久,网上也不少,可就是读取文件时总是找不到文件在哪(我放在classes目录下了)。最后终于成功,记下,以做纪念。 

    Java代码  收藏代码
    1. package com.web.connection;  
    2.   
    3. import java.io.IOException;  
    4. import java.io.InputStream;  
    5. import java.sql.Connection;  
    6. import java.sql.DriverManager;  
    7. import java.sql.SQLException;  
    8. import java.util.Properties;  
    9. import java.util.logging.Level;  
    10. import java.util.logging.Logger;  
    11.   
    12. public class Conn {  
    13.     private String fileName="/db.properties";//这里是指放在classes下,如果有包的话,前面加包名即可。例:/com/web/db.properties  
    14.     private String driver = "";  
    15.     private String url = "";  
    16.     private String username ="";  
    17.     private String password = "";  
    18.     Connection conn=null;  
    19.       
    20.   
    21.     public  Connection  getConn(){  
    22.         Properties p = new Properties();  
    23.         try {  
    24.             InputStream in = Conn.class.getResourceAsStream(fileName);//这里有人用new FileInputStream(fileName),不过这种方式找不到配置文件。有人说是在classes下,我调过了,不行。  
    25.             p.load(in);  
    26.             in.close();  
    27.             if(p.containsKey("driver")){  
    28.                 this.driver = p.getProperty("driver");  
    29.             }  
    30.             if(p.containsKey("url")){  
    31.                 this.url = p.getProperty("url");  
    32.             }  
    33.             if(p.containsKey("user")){  
    34.                 this.username = p.getProperty("user");  
    35.             }  
    36.             if(p.containsKey("password")){  
    37.                 this.password = p.getProperty("password");  
    38.             }  
    39.         } catch (IOException ex) {  
    40.             Logger.getLogger(Conn.class.getName()).log(Level.SEVERE, null, ex);  
    41.         }  
    42.         System.out.println(p.getProperty("driver"));  
    43.        try {  
    44.             Class.forName(this.driver);  
    45.             conn = DriverManager.getConnection(this.url,this.username,this.password);  
    46.         } catch (SQLException ex) {  
    47.             ex.printStackTrace();  
    48.             System.out.print("获取连接异常");  
    49.         } catch (ClassNotFoundException ex) {  
    50.             System.out.print("加载驱动出错");  
    51.             ex.printStackTrace();;  
    52.         }  
    53.         return conn;  
    54.     }  
    55. }  
    网上文章常见的几种读取.properties文件的方式

    1、使用java.util.Properties类的load()方法 示例:

    Java代码  收藏代码
    1. InputStream in = lnew BufferedInputStream(new FileInputStream(name));   
    2. Properties p = new Properties();   
    3. p.load(in);  



    2、使用java.util.ResourceBundle类的getBundle()方法 
    示例:

    Java代码  收藏代码
    1. ResourceBundle rb = ResourceBundle.getBundle(name, Locale.getDefault());   



    用ResourceBundle读取.properties文件可避免路径问题 
                我在jar里读取.properties文件时,总是找不到文件路径,后来用ResourceBundle读取.properties文件即可避免路径问题,代码如下: 
         

    //process为文件名,切记不要加 .properties, URL是文件里的键名 

    Java代码  收藏代码
    1.     ResourceBundle bundle = ResourceBundle.getBundle("com.ihandy.smsoc.app.process");  
    2.    String s = bundle.getString("URL");  
    3. System.out.println(s);  
    4. pURL = s;  




    3、使用java.util.PropertyResourceBundle类的构造函数 
    示例: 

    Java代码  收藏代码
    1. InputStream in = new BufferedInputStream(new FileInputStream(name));   
    2. ResourceBundle rb = new PropertyResourceBundle(in);   



    4、使用class变量的getResourceAsStream()方法 
    示例:
     

    Java代码  收藏代码
    1. InputStream in = 类名.class.getResourceAsStream(name);   
    2. Properties p = new Properties();   
    3. p.load(in);   


    5、使用class.getClassLoader()所得到的java.lang.ClassLoader的getResourceAsStream()方法 示例: 

    Java代码  收藏代码
    1. InputStream in = 类名.class.getClassLoader().getResourceAsStream(name);   
    2. Properties p = new Properties();   
    3. p.load(in);   



    6、使用java.lang.ClassLoader类的getSystemResourceAsStream()静态方法 示例: 

    Java代码  收藏代码
    1. InputStream in = ClassLoader.getSystemResourceAsStream(name);   
    2. Properties p = new Properties();   
    3. p.load(in);   



    7、Servlet中可以使用javax.servlet.ServletContext的getResourceAsStream()方法 示例: 

    Java代码  收藏代码
      1. InputStream in = context.getResourceAsStream(path);   
      2. Properties p = new Properties();   
      3. p.load(in);   
  • 相关阅读:
    Spring 事务不回滚
    Druid详细配置信息
    Servlet和JSP规范及版本对应关系
    CDN(内容分发网络)技术原理
    开发者需要了解的WebKit
    浏览器的渲染原理简介
    在浏览器中输入Google.com并且按下回车之后发生了什么?
    为什么说DOM操作很慢
    亿级Web系统搭建——单机到分布式集群
    linux下用rinetd做端口转发
  • 原文地址:https://www.cnblogs.com/mamo/p/3600017.html
Copyright © 2011-2022 走看看