java读取配置文件的信息
1. 首先,工程结构如下:
注:
a. 蓝色标注的两个文件是和com包平级的,都在src下。EnnNotificationPushProxy.ini是这个工程的配置文件,log4j.properties是log4j的配置文件。
b. 红色标注的两个文件,ConfigUtil.java是用来读取EnnNotificationPushProxy.ini的,LogUtil.java是读取log4j.properties的。
2. ConfigUtil.java内容:
package com.ecity.enn.notification.proxy.util;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.Properties;
public class ConfigUtil {
private static final String INI_FILE_NAME = "/EnnNotificationPushProxy.ini";
private static HashMap<String, String> propertyMap = null;
static {
propertyMap = new HashMap<String, String>();
String path = URLUtil.getClassPath(ConfigUtil.class) + INI_FILE_NAME;
LogUtil.debug("EnnNotificationPushProxy.ini path=" + path);
File file = new File(path);
FileInputStream inStream = null;
try {
inStream = new FileInputStream(file);
} catch (FileNotFoundException e) {
LogUtil.error(e);
}
Properties properties = new Properties();
try {
properties.load(inStream);
} catch (IOException e) {
LogUtil.error(e);
}
@SuppressWarnings("unchecked")
Enumeration<String> keys = (Enumeration<String>) properties.propertyNames();
while (keys.hasMoreElements()) {
String key = keys.nextElement();
propertyMap.put(key.toLowerCase(), properties.getProperty(key));
}
}
public static String get(String key) {
return propertyMap.get(key.toLowerCase());
}
public static int getInt(String key) {
String valueStr = propertyMap.get(key.toLowerCase());
int value = 0;
try {
value = Integer.valueOf(valueStr);
} catch (Exception e) {
LogUtil.error(e);
value = 0;
}
return value;
}
public static long getLong(String key) {
String valueStr = propertyMap.get(key.toLowerCase());
long value = 0;
try {
value = Long.valueOf(valueStr);
} catch (Exception e) {
LogUtil.error(e);
value = 0;
}
return value;
}
public static void set(String key, String value) {
if (get(key) == null) {
propertyMap.put(key, value);
}
}
}
3. LogUtil.java内容:
package com.ecity.enn.notification.proxy.util;
import org.apache.log4j.Logger;
import org.apache.log4j.PropertyConfigurator;
public class LogUtil {
private static final Logger logger;
private static final String INI_FILE_NAME = "/log4j.properties";
private static final String TAG = "EnnNotificationPushProxy";
static {
System.out.println("ProjectHomePath=" + URLUtil.getProjectHomePath());
System.setProperty("WORKDIR", URLUtil.getProjectHomePath());
String path = URLUtil.getClassPath(LogUtil.class) + INI_FILE_NAME;
PropertyConfigurator.configure(path);
logger = Logger.getLogger(TAG);
}
public static void debug(Object message) {
logger.info(message);
}
public static void debug(String message, Throwable e) {
logger.info(message, e);
}
public static void info(String message) {
logger.info(message);
}
public static void info(String message, Throwable e) {
logger.info(message, e);
}
public static void error(String message) {
logger.error(message);
}
public static void error(Object message, Throwable e) {
logger.error(message, e);
}
public static void error(Throwable e) {
logger.error("", e);
}
}
注:注意WORKDIR的值的设置。它的值是当前工程的位置。
4. log4j.properties内容:
log4j.rootLogger=ALL, ServerDailyRollingFile, stdout
log4j.appender.ServerDailyRollingFile=org.apache.log4j.DailyRollingFileAppender
log4j.appender.ServerDailyRollingFile.DatePattern='.'yyyy-MM-dd
log4j.appender.ServerDailyRollingFile.File=${WORKDIR}/logs/EnnNotificationPushProxy.log
log4j.appender.ServerDailyRollingFile.layout=org.apache.log4j.PatternLayout
log4j.appender.ServerDailyRollingFile.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n
log4j.appender.ServerDailyRollingFile.Append=true
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH:mm:ss} %p [%c] %m%n
注:注意WORKDIR变量的使用。这个配置下,logs文件生成在工程的根目录。
5. 在ConfigUtil.java和LogUtil.java中,都使用到了URLUtil类。如下:
package com.ecity.enn.notification.proxy.util;
import java.io.File;
import java.io.UnsupportedEncodingException;
import java.net.URL;
/**
* <p>
* Title:URL辅助工具类
* </p>
*/
public class URLUtil {
/**
*
* Description:取得当前类所在的文件
*/
public static File getClassFile(Class<?> clazz) {
URL path = clazz.getResource(clazz.getName().substring(clazz.getName().lastIndexOf(".") + 1) + ".class");
if (path == null) {
String name = clazz.getName().replaceAll("[.]", "/");
path = clazz.getResource("/" + name + ".class");
}
return new File(path.getFile());
}
/**
* Description:同getClassFile 解决中文编码问题
*/
public static String getClassFilePath(Class<?> clazz) {
try {
return java.net.URLDecoder.decode(getClassFile(clazz).getAbsolutePath(), "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
return "";
}
}
/**
*
* Description:取得当前类所在的ClassPath目录
*
* @param clazz
* @return
* @mail sunyujia@yahoo.cn
* @since:Sep 21, 2008 12:32:27 PM
*/
public static File getClassPathFile(Class<?> clazz) {
File file = getClassFile(clazz);
for (int i = 0, count = clazz.getName().split("[.]").length; i < count; i++)
file = file.getParentFile();
if (file.getName().toUpperCase().endsWith(".JAR!")) {
file = file.getParentFile();
}
return file;
}
/**
*
* Description: 同getClassPathFile 解决中文编码问题
*
* @param clazz
* @return
* @mail sunyujia@yahoo.cn
* @since:Sep 21, 2008 1:10:37 PM
*/
public static String getClassPath(Class<?> clazz) {
try {
return java.net.URLDecoder.decode(getClassPathFile(clazz).getAbsolutePath(), "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
return "";
}
}
public static String getProjectHomePath() {
String path = getClassPath(URLUtil.class);
String webAppPath = path.substring(0, path.toUpperCase().lastIndexOf("WEB-INF")).replaceAll("%20", " ");
return webAppPath;
}
public static void main(String[] args) throws UnsupportedEncodingException {
System.out.println(getClassFilePath(URLUtil.class));
System.out.println(getClassPath(URLUtil.class));
}
}
6. 最终部署结果:
a. 两个配置文件的位置在classes下。如下:
b. logs文件夹在项目根目录下。log文件在logs文件夹下。如下:
java读取配置文件的信息的更多相关文章
- java读取配置文件的几种方法
java读取配置文件的几种方法 原文地址:http://hbcui1984.iteye.com/blog/56496 在现实工作中,我们常常需要保存一些系统配置信息,大家一般都会选择配 ...
- Java读取配置文件的方式
Java读取配置文件的方式-笔记 1 取当前启动文件夹下的配置文件 一般来讲启动java程序的时候.在启动的文件夹下会有配置文件 classLoader.getResource(&qu ...
- Java读取数据源相关信息
一.采用读取数据源配置文件的方式 package com.ofsp.utils; import java.io.IOException; import java.io.InputStream; imp ...
- spring boot使用java读取配置文件,DateSource测试,BomCP测试,AnnotationConfigApplicationContext的DataSource注入
一.配置注解读取配置文件 (1)@PropertySource可以指定读取的配置文件,通过@Value注解获取值 实例: @PropertySource(val ...
- java读取配置文件(转)
转载:http://blog.csdn.net/gaogaoshan/article/details/8605887 java 4种方式读取配置文件 + 修改配置文件 方式一:采用Servle ...
- 转:java读取配置文件的几种方法
转自: http://www.iteye.com/topic/56496 在现实工作中,我们常常需要保存一些系统配置信息,大家一般都会选择配置文件来完成,本文根据笔者工作中用到的读取配置文件的方法小小 ...
- java读取配置文件
java 读取文件可以用字节流和字符流. 由于一个汉字占两个字节,所以如果配置文件中有汉字,用字节流读取,会出现乱码. 用字符流则不会出现乱码. 配置文件 b.properties 文件如下: fam ...
- Java 读取配置文件数据
Properties类 Properties类,是一个工具类,包含在java.util包中. 功能:可以保存持久的属性,通常用来读取配置文件或者属性文件,将文件中的数据读入properties对象中, ...
- java读取配置文件方法以及工具类
第一种方式 : java工具类读取配置文件工具类 只是案例代码 抓取异常以后的代码自己处理 import java.io.FileNotFoundException; import java.io. ...
随机推荐
- yum常用命令大全
yum命令是在Fedora和RedHat以及SUSE中基于rpm的软件包管理器,它可以使系统管理人员交互和自动化地更细与管理RPM软件包,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性 ...
- myeclipse创建hibernate工程
1.创建数据库: from blog http://www.cnblogs.com/zhaocundang/p/9061959.html 使用navicat mysql IDE: 创建数据库 book ...
- 用NextResult方法取得多个Result Set
http://dotnet.chinaitlab.com/ADONET/757364.html 从 ADO.NET 1.x 开始,DataReader 就可以在单一次的查询动作中,「批次 (batch ...
- Collections.synchronizedMap()与ConcurrentHashMap的区别
前面文章提到Collections.synchronizedMap()与ConcurrentHashM两者都提供了线程同步的功能.那两者的区别在哪呢?我们们先来看到代码例子. 下面代码实现一个线 ...
- android下载网络图片并缓存
异步下载网络图片,并提供是否缓存至内存或外部文件的功能 异步加载类AsyncImageLoader public void downloadImage(final String url, final ...
- Python中通过lambda抛异常的奇技淫巧
假设我们需要一个函数什么事都不干,只是抛出异常(在某些系统中有些handler就是干这事的),我们可以很直观的写出下面的代码: def func(): raise Exception("th ...
- 正则表达式中,[\s\S]* 什么意思
https://blog.csdn.net/haoyuedangkong_fei/article/details/53781936 例如:[a-z]表示从a到z之间的任意一个. 不是这样的吗?谁能给我 ...
- 10.11 rbac权限
2018-10-11 12:25:11 现在写代码时候,不要好多代码放在一块!注重解耦!!!!! 把权限放到中间件里面,每次访问的时候都用到! 自己的网站弄完了,博客网站已经正式上线,就是有点丑! w ...
- win10 开启蓝 由于其配置信息(注册表中的)不完整或已损坏
在管理员命令提示符下键入以下命令: Dism /Online /Cleanup-Image /ScanHealth 这条命令将扫描全部系统文件并和官方系统文件对比,扫描计算机中的不一致情况. Dism ...
- ABP之事件总线(1)
什么是事件总线呢?官方的文档说,它是一个单例对象,由其他的类共同拥有,可以用来触发和处理事件.这个东西确实比较陌生,为什么要使用事件总线,或者说事件总线的优势是什么???首先我们可以明确的是,事件总线 ...