java 配置参数_给你的JAVA程序配置参数(Properties的使用)

我们在写JAVA程序时,很多时候运行程序的参数是需要动态改变的

测试时一系列参数,运行时一系列参数

又或者数据库地址也需要配一套参数,以方便今后的动态部署

这些变量的初始化,我们在写小DEMO时完全可以写死在JAVA文件中

但程序需要发布或者局部部署时,这些参数就需要脱离程序代码了

我们有多种存放参数的方式,比如数据库、XML文件又或者直接是txt文件

现在介绍一种使用JAVA,简单方便的参数读取方式

.properties文件,我们并不陌生,很多优秀的框架中就能看到它的存在,比如Hibernate

在src文件目录下,新建一个后缀为.properties的文件,用任意文本编辑器打开它,就可以使用键值对的方式设置您程序的运行参数了

类似于这样

#wangqun fd60e46db0dc119cfea740c3375fd7c4

#toAccountId=fd60e46db0dc119cfea740c3375fd7c4

#huangshi 1645a78135328c4b

toAccountId=1645a78135328c4b

#tangwei 6c0f7514f4bd0016

#shixiaoping 98f30bad9e6789af

#toAccountId=6c0f7514f4bd0016

#toAccountId=6c0f7514f4bd0016,1645a78135328c4b,98f30bad9e6789af

#cron=0 32 8-11,14-20/1 * * ?cron=0/10 * * * * ?fileName=d\:/\u59DC\u5830\u5468\u79EF\u5206\u7BA1\u63A7\u53CA\u53CC\u767E\u5146\u8BAD\u7EC3\u84250830.xlsx

sheetName=\u6C47\u603B

fromIndex=0,1toIndex=48,12#fromIndex=1,4#toIndex=13,12dirPath=C:/apache-tomcat-8.0.28/webapps/test/urlPath=http://61.132.43.176:8081/test/

database_host=132.240.9.36database_port=1521database_user=jy

database_name=yxdb

database_pwd=OVQwu8QSm4CWktEZdnjtxg==sql_str=select *from hs_bb_rbb r order by r.no

modify_sheet=sheet1

modify_from=1,0time_cell=1,4

注意一下几点:

一、用#号表示注释,可以多录入一些配置可能,运行时动态注释或者打开,比较方便

二、.properties明文存储,所以敏感字符需要加密,比如数据的密码

三、遇到中文,是个棘手的问题,最简单的方式是使用MyEclipse的properties文件编辑器来写入,会自动将中文转码

四、所有参数只可以以字符串形式存储,至于类型转换,请在JAVA中解析完成

五、适用于只读不写的参数配置,如果程序运行过程中需要修改这些环境参数,建议考虑数据库读写方式,而不是properties

下面是JAVA程序,mian函数一开始就可以对这个properties文件进行读取

public static void main(String[] args) throwsException{//读取properties配置文件

Properties prop=newProperties();

prop.load(QuartzDemo.class.getResourceAsStream("/set.properties"));String cron=prop.getProperty("cron","0/10 * 8-7 * * ?");String fileName=prop.getProperty("fileName","d:/2014年1月营销活动报表140116.xlsx");

String sheetName=prop.getProperty("sheetName", "支局视图");

String dirPath=prop.getProperty("dirPath","C:/apache-tomcat-8.0.28/webapps/test/");

String urlPath=prop.getProperty("urlPath","http://61.132.43.176:8081/test/");

String fromIndexStr=prop.getProperty("fromIndex","0,0");

String toIndexStr=prop.getProperty("toIndex", "17,20");

String database_host=prop.getProperty("database_host","");

String database_port=prop.getProperty("database_port","");

String database_user=prop.getProperty("database_user","");

String database_name=prop.getProperty("database_name","");

String database_pwd=DESHelper.decrypt(prop.getProperty("database_pwd",""),"newflypig");

String sql_str=prop.getProperty("sql_str","");

String modify_sheet=prop.getProperty("modify_sheet","");

String modify_fromStr=prop.getProperty("modify_from","0,0");

String[] splitStr=fromIndexStr.split(",");int[] fromIndex={Integer.parseInt(splitStr[0]),Integer.parseInt(splitStr[1])};

splitStr=toIndexStr.split(",");int[] toIndex={Integer.parseInt(splitStr[0]),Integer.parseInt(splitStr[1])};

splitStr=modify_fromStr.split(",");int[] modify_from={Integer.parseInt(splitStr[0]),Integer.parseInt(splitStr[1])};

}

Properties类提供了非常便捷的读取properties文件的操作,还包括一些默认值的配置,再次需要注意的是,只能读String,如果遇到其他数据类型,聪明的你一定知道怎样用String类型转换这些类型吧。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值