【java基础】——Java Properties类读取配置文件,
【java基础】——Java Properties类读取配置文件,
一、Java Properties类
Java中有个比较重要的类Properties(Java.util.Properties),主要用于读取Java的配置文件,各种语言都有自己所支持的配置文件,配置文件中很多变量是经常改变的,这样做也是为了方便用户,让用户能够脱离程序本身去修改相关的变量设置。像Python支持的配置文件是.ini文件,同样,它也有自己读取配置文件的类ConfigParse,方便程序员或用户通过该类的方法来修改.ini配置文件。在Java中,其配置文件常为.properties文件,格式为文本文件,文件的内容的格式是“键=值”的格式,文本注释信息可以用"#"来注释。
Properties类继承自Hashtable,如下:
它提供了几个主要的方法:
1. getProperty ( String key),用指定的键在此属性列表中搜索属性。也就是通过参数 key ,得到 key 所对应的 value。
2. load ( InputStream inStream),从输入流中读取属性列表(键和元素对)。通过对指定的文件(比如说上面的 test.properties 文件)进行装载来获取该文件中的所有键 - 值对。以供 getProperty ( String key) 来搜索。
3. setProperty ( String key, String value) ,调用 Hashtable 的方法 put 。他通过调用基类的put方法来设置 键 - 值对。
4. store ( OutputStream out, String comments),以适合使用 load 方法加载到 Properties 表中的格式,将此 Properties 表中的属性列表(键和元素对)写入输出流。与 load 方法相反,该方法将键 - 值对写入到指定的文件中去。
5. clear (),清除所有装载的 键 - 值对。该方法在基类中提供。
二、实例
1、写了一个操作mysql的数据库实例,代码结构如下:
2、 dbconfig.properties文件
CLASS_NAME=com.mysql.jdbc.Driver
DATABASE_URL=jdbc:mysql
SERVER_IP=localhost
SERVER_PORT=3306
DATABASE_SID=codecore
USERNAME=root
PASSWORD=123456
3、config.java
package com.codecore.dbutil;
import java.io.IOException;
import java.util.Properties;
public class Config {
private static Properties prop = new Properties();
static{
try {
//加载dbconfig.properties配置文件
prop.load(Config.class.getResourceAsStream("dbconfig.properties"));
} catch (IOException e) {
e.printStackTrace();
}
}
//设置常量
public static final String CLASS_NAME = prop.getProperty("CLASS_NAME");
public static final String DATABASE_URL = prop.getProperty("DATABASE_URL");
public static final String SERVER_IP = prop.getProperty("SERVER_IP");
public static final String SERVER_PORT = prop.getProperty("SERVER_PORT");
public static final String DATABASE_SID = prop.getProperty("DATABASE_SID");
public static final String USERNAME = prop.getProperty("USERNAME");
public static final String PASSWORD = prop.getProperty("PASSWORD");
}
4、DBConn.java文件
package com.codecore.dbutil;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
public class DBConn {
//三属性、四方法
//三大核心接口
private Connection conn = null;
private PreparedStatement pstmt = null;
private ResultSet rs = null;
//四个方法
//method1: 创建数据库的连接
private void getConntion(){
try {
//1: 加载连接驱动,Java反射原理
Class.forName(Config.CLASS_NAME);
//2:创建Connection接口对象,用于获取MySQL数据库的连接对象。三个参数:url连接字符串 账号 密码
String url = Config.DATABASE_URL+"://"+Config.SERVER_IP+":"+Config.SERVER_PORT+"/"+Config.DATABASE_SID;
conn = DriverManager.getConnection(url,Config.USERNAME,Config.PASSWORD);
} catch (ClassNotFoundException e) {
e.printStackTrace();
} catch (SQLException e) {
e.printStackTrace();
}
}
//method2:关闭数据库的方法
public void closeConn(){
if(rs!=null){
try {
rs.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(pstmt!=null){
try {
pstmt.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
//method3: 专门用于发送增删改语句的方法
public int execOther(final String strSQL,final Object[] params ){
//1、获取数据库连接
getConntion();
//2、预先打印出即将执行的SQL语句(便于项目测试,仿Hibernate框架)
try {
//3、创建Statement接口对象
pstmt = conn.prepareStatement(strSQL);
//4、动态为pstmt对象赋值
for(int i=0; i< params.length ;i++){
pstmt.setObject(i+1, params[i]);
}
//5、使用Statement对象发送SQL语句
int affectedRows = pstmt.executeUpdate();
//6、返回结果
return affectedRows;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return -1;
}
}
//method4: 专门用于发送查询语句
public ResultSet execQuery(final String strSQL,final Object[] params){
//1、获取数据库连接
getConntion();
//2、预先打印出即将执行的SQL语句(便于项目测试,仿Hibernate框架)
try {
//3、创建PreparedStatement接口对象
pstmt = conn.prepareStatement(strSQL);
//4、动态为pstmt对象赋值
for(int i=0; i< params.length ;i++){
pstmt.setObject(i+1, params[i]);
}
//5、使用Statement对象发送SQL语句
rs = pstmt.executeQuery();
//6、返回结果
return rs;
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
return null;
}
}
}
相关文章
- 暂无相关文章
用户点评