java項目中讀取jdbc.properties文件操作
java內(nèi)容
Properties props = Resources.getResourceAsProperties("jdbc.properties");
String url = props.getProperty("jdbc.url");
String driver = props.getProperty("jdbc.driverClass");
String username = props.getProperty("jdbc.username");
String password = props.getProperty("jdbc.password");
Class.forName(driver).newInstance();
Connection conn = (Connection) DriverManager.getConnection(url, username, password);
jdbc.properties文件內(nèi)容
jdbc.driverClass = com.mysql.jdbc.Driver jdbc.url = jdbc\:mysql\://127.0.0.1\:3306/LY?useUnicode\=true&characterEncoding\=UTF-8&zeroDateTimeBehavior\=convertToNull&allowMultiQueries\=true jdbc.username = root jdbc.password = root jdbc.minPoolSize=2 jdbc.maxPoolSize=20 jdbc.checkoutTimeout=3000 jdbc.maxStatements=50 jdbc.testConnectionOnCheckin = false jdbc.idleConnectionTestPeriod =18000
補充知識:模仿com.alibaba.fastjson.JSONObject取值的PropertiesUtils
1.依賴于:fastjson
<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.39</version> </dependency>
2.話不多說,上代碼
package com.gy.common.util;
import java.io.IOException;
import java.io.InputStream;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.sql.Timestamp;
import java.util.Date;
import java.util.Properties;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.alibaba.fastjson.util.TypeUtils;
/**
* java讀取配置文件
*
* @author Neo 2017-5-12
* @version 1.1
*
*/
@SuppressWarnings({ "unchecked", "rawtypes" })
public class PropertiesUtils {
private static Logger logger = LoggerFactory.getLogger(PropertiesUtils.class);
private static Properties properties;
private static final String PROPERTIES_EGIS_FILE_NAME = "application/config.properties";
static {
properties = new Properties();
InputStream scmsStream = null;
try {
scmsStream = PropertiesUtils.class.getClassLoader().getResourceAsStream(PROPERTIES_EGIS_FILE_NAME);
properties.load(scmsStream);
logger.info("PropertiesUtils", "staitc init prop", properties.toString());
} catch (Exception e) {
} finally {
try {
if (scmsStream != null) {
scmsStream.close();
}
} catch (Exception e) {
}
}
}
public static String getProperty(String key) {
String result = properties.getProperty(key);
return result;
}
public static String getProperty(String key, String defaultValue) {
String result = properties.getProperty(key, defaultValue);
return result;
}
public static String getProperties(String propertiesName, String key) {
Properties props = new Properties();
InputStream inputStream = null;
try {
inputStream = PropertiesUtils.class.getClassLoader().getResourceAsStream(propertiesName);
props.load(inputStream);
} catch (IOException e) {
} finally {
try {
if (inputStream != null) {
inputStream.close();
}
} catch (Exception e) {
}
}
return props.getProperty(key);
}
public static Object getObject(String key, Class clazz) {
Object obj = getProperty(key);
return TypeUtils.castToJavaBean(obj, clazz);
}
public static Boolean getBoolean(String key) {
Object value = getProperty(key);
if (value == null)
return null;
else
return TypeUtils.castToBoolean(value);
}
public static byte[] getBytes(String key) {
Object value = getProperty(key);
if (value == null)
return null;
else
return TypeUtils.castToBytes(value);
}
public static boolean getBooleanValue(String key) {
Object value = getProperty(key);
if (value == null)
return false;
else
return TypeUtils.castToBoolean(value).booleanValue();
}
public static Byte getByte(String key) {
Object value = getProperty(key);
return TypeUtils.castToByte(value);
}
public static byte getByteValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0;
else
return TypeUtils.castToByte(value).byteValue();
}
public static Short getShort(String key) {
Object value = getProperty(key);
return TypeUtils.castToShort(value);
}
public static short getShortValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0;
else
return TypeUtils.castToShort(value).shortValue();
}
public static Integer getInteger(String key) {
Object value = getProperty(key);
return TypeUtils.castToInt(value);
}
public static int getIntValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0;
else
return TypeUtils.castToInt(value).intValue();
}
public static Long getLong(String key) {
Object value = getProperty(key);
return TypeUtils.castToLong(value);
}
public static long getLongValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0L;
else
return TypeUtils.castToLong(value).longValue();
}
public static Float getFloat(String key) {
Object value = getProperty(key);
return TypeUtils.castToFloat(value);
}
public static float getFloatValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0.0F;
else
return TypeUtils.castToFloat(value).floatValue();
}
public static Double getDouble(String key) {
Object value = getProperty(key);
return TypeUtils.castToDouble(value);
}
public static double getDoubleValue(String key) {
Object value = getProperty(key);
if (value == null)
return 0.0D;
else
return TypeUtils.castToDouble(value).doubleValue();
}
public static BigDecimal getBigDecimal(String key) {
Object value = getProperty(key);
return TypeUtils.castToBigDecimal(value);
}
public static BigInteger getBigInteger(String key) {
Object value = getProperty(key);
return TypeUtils.castToBigInteger(value);
}
public static String getString(String key) {
Object value = getProperty(key);
if (value == null)
return null;
else
return value.toString();
}
public static Date getDate(String key) {
Object value = getProperty(key);
return TypeUtils.castToDate(value);
}
public static java.sql.Date getSqlDate(String key) {
Object value = getProperty(key);
return TypeUtils.castToSqlDate(value);
}
public static Timestamp getTimestamp(String key) {
Object value = getProperty(key);
return TypeUtils.castToTimestamp(value);
}
public static void main(String[] args) {
if(getBooleanValue("isNeedLogin"))
System.out.println("aaa");
}
}
以上這篇java項目中讀取jdbc.properties文件操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java的DataInputStream和DataOutputStream數(shù)據(jù)輸入輸出流
這里我們來看一下Java的DataInputStream和DataOutputStream數(shù)據(jù)輸入輸出流的使用示例,兩個類分別繼承于FilterInputStream和FilterOutputStream:2016-06-06
在已有spring的基礎(chǔ)上集成hibernate的實例講解
下面小編就為大家?guī)硪黄谝延衧pring的基礎(chǔ)上集成hibernate的實例講解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-11-11
帶有@Transactional和@Async的循環(huán)依賴問題的解決
這篇文章主要介紹了帶有@Transactional和@Async的循環(huán)依賴問題的解決,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
SpringBoot?整合?EasyExcel?實現(xiàn)自由導(dǎo)入導(dǎo)出功能
在實際的業(yè)務(wù)系統(tǒng)開發(fā)過程中,操作 Excel 實現(xiàn)數(shù)據(jù)的導(dǎo)入導(dǎo)出基本上是個非常常見的需求,這篇文章主要介紹了SpringBoot?整合?EasyExcel?實現(xiàn)自由導(dǎo)入導(dǎo)出功能,需要的朋友可以參考下2024-06-06
Java高級用法中的JNA類型映射注意細節(jié)及使用問題
本文介紹了在使用JNA方法映射中應(yīng)該注意的一些細節(jié)和具體的使用問題,對java??JNA類型映射注意細節(jié)感興趣的朋友一起看看吧2022-04-04
jeefast和Mybatis實現(xiàn)三級聯(lián)動的示例代碼
這篇文章主要介紹了jeefast和Mybatis實現(xiàn)三級聯(lián)動的示例代碼,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10
Springboot集成knife4j實現(xiàn)風(fēng)格化API文檔
這篇文章主要介紹了Springboot如何集成knife4j實現(xiàn)風(fēng)格化API文檔,幫助大家更好的使用springboot框架,感興趣的朋友可以了解下2020-12-12

