我们在写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,1 toIndex=48,12 #fromIndex=1,4 #toIndex=13,12 dirPath=C:/apache-tomcat-8.0.28/webapps/test/ urlPath=http://61.132.43.176:8081/test/ database_host=132.240.9.36 database_port=1521 database_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,0 time_cell=1,4
注意一下几点:
一、用#号表示注释,可以多录入一些配置可能,运行时动态注释或者打开,比较方便
二、.properties明文存储,所以敏感字符需要加密,比如数据的密码
三、遇到中文,是个棘手的问题,最简单的方式是使用MyEclipse的properties文件编辑器来写入,会自动将中文转码
四、所有参数只可以以字符串形式存储,至于类型转换,请在JAVA中解析完成
五、适用于只读不写的参数配置,如果程序运行过程中需要修改这些环境参数,建议考虑数据库读写方式,而不是properties
下面是JAVA程序,mian函数一开始就可以对这个properties文件进行读取
public static void main(String[] args) throws Exception{ //读取properties配置文件 Properties prop=new Properties(); 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类型转换这些类型吧。