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);   
原文地址:https://www.cnblogs.com/mamo/p/3600017.html