JAVA基础——使用配置文件
一. 前言
日常我们做项目中,我们经常会遇到这样的情况:由于开发环境和生产环境的不同,项目部署在生产环境之前,有些参数我们并不知道如何取值。例如:数据库链接设定,我们在部署生产环境之前,无法预知客户的数据库连接地址是什么,也无法预知数据库的用户名和密码。这种情况下,就需要我们将数据库的连接参数保存到某个文件中,项目需要链接数据库的时候,就从该文件中获取相关参数,以保证系统在生产环境中的正常运转。
为了解决这种问题,我们就需要用到JAVA的properties文件。
二. 介绍
JAVA的配置文件是以properties为扩展名的,其内容为键值对形式存储,且键名和键值都是字符串格式。JAVA提供java.util.Properties类,可以非常方便的读取配置文件的信息。
三. 使用
1. 新建JAVA工程。
2. 新建properties文件,名称为application.properties。
SQL.url=jdbc:sqlserver://127.0.0.1; DatabaseName=BaseFrame
SQL.userName=sa
SQL.passWord=-+
其中,SQL.url定义了数据库的链接地址;SQL.userName定义了用户名;SQL.passWord定义了密码。
3. 新建Main.class并为其添加main方法。
package com.luych.stu;
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Properties;
public class Main {
public static void main(String[] args) throws Exception {
// 将配置文件加载到流中
InputStream in = Main.class.getClassLoader().getResourceAsStream("application.properties");
// 创建并加载配置文件
Properties pro = new Properties();
pro.load(in);
// 获取配置文件定义的值
String url = pro.getProperty("SQL.url");
System.out.println("配置文件中SQL.url的值为:"+url);
String userName = pro.getProperty("SQL.userName");
System.out.println("配置文件中SQL.userName的值为:"+userName);
String passWord = pro.getProperty("SQL.passWord");
System.out.println("配置文件中SQL.passWord的值为:"+passWord);
// 使用
Connection con = DriverManager.getConnection(url, userName, passWord);
String sql = "select * from tbUser";
PreparedStatement pstmt = con.prepareStatement(sql);
ResultSet result = pstmt.executeQuery();
int col = result.getMetaData().getColumnCount();
System.out.println("============================");
while (result.next()) {
for (int i = 1; i <= col; i++) {
System.out.print(result.getString(i) + "\t");
if ((i == 2) && (result.getString(i).length() < 8)) {
System.out.print("\t");
}
}
System.out.println("");
}
System.out.println("============================");
}
}
package com.luych.stu; import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Properties; public class Main {
public static void main(String[] args) throws Exception {
// 将配置文件加载到流中
InputStream in = Main.class.getClassLoader().getResourceAsStream("application.properties");
// 创建并加载配置文件
Properties pro = new Properties();
pro.load(in);
// 获取配置文件定义的值
String url = pro.getProperty("SQL.url");
System.out.println("配置文件中SQL.url的值为:"+url);
String userName = pro.getProperty("SQL.userName");
System.out.println("配置文件中SQL.userName的值为:"+userName);
String passWord = pro.getProperty("SQL.passWord");
System.out.println("配置文件中SQL.passWord的值为:"+passWord);
// 使用
Connection con = DriverManager.getConnection(url, userName, passWord);
String sql = "select * from tbUser";
PreparedStatement pstmt = con.prepareStatement(sql);
ResultSet result = pstmt.executeQuery();
int col = result.getMetaData().getColumnCount();
System.out.println("============================");
while (result.next()) {
for (int i = 1; i <= col; i++) {
System.out.print(result.getString(i) + "\t");
if ((i == 2) && (result.getString(i).length() < 8)) {
System.out.print("\t");
}
}
System.out.println("");
}
System.out.println("============================");
}
}
打印结果为:
配置文件中SQL.url的值为:jdbc:sqlserver://127.0.0.1; DatabaseName=BaseFrame
配置文件中SQL.userName的值为:sa
配置文件中SQL.passWord的值为:-+
============================
705244A7-B642-4161-9EC8-966044F15F16 admin 系统管理员 123 15295699492 123@abc.com
4FE0FF3F-B015-482D-AB71-3321D57A7EF4 test1 Test1 123 15295699492 123@abc.com
============================
如此,我们就可以将配置文件中的值读取并使用了。
四. 目录结构

五. 总结
其实大家可能会想到:我直接将url、userName、passWord定义final变量中不就可以了嘛?这样的缺点是我们在将项目部署到生产环境之前,还需要重新调整我们的JAVA代码,并编译生成war包或jar包。而定义到环境变量中则不需要重新编译即可正常运行。
JAVA基础——使用配置文件的更多相关文章
- java基础50 配置文件类(Properties)
1. 配置文件类Properties的概念 主要生产配置文件与读取配置文件的信息 2.Properties要注意的细节 1.如果配置文件一旦使用了中文,那么在使用store方法生产的配置文件额时候字符 ...
- [Java面经]干货整理, Java面试题(覆盖Java基础,Java高级,JavaEE,数据库,设计模式等)
如若转载请注明出处: http://www.cnblogs.com/wang-meng/p/5898837.html 谢谢.上一篇发了一个找工作的面经, 找工作不宜, 希望这一篇的内容能够帮助到大 ...
- 给Java新手的一些建议----Java知识点归纳(Java基础部分)
写这篇文章的目的是想总结一下自己这么多年来使用java的一些心得体会,主要是和一些java基础知识点相关的,所以也希望能分享给刚刚入门的Java程序员和打算入Java开发这个行当的准新手们,希望可以给 ...
- 黑马程序员:Java基础总结----反射
黑马程序员:Java基础总结 反射 ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 反射 反射的基石:Class类 Class类代表Java类,它的各个实例对象又分别 ...
- 学习Spring必学的Java基础知识(1)----反射(转)
引述要学习Spring框架的技术内幕,必须事先掌握一些基本的Java知识,正所谓"登高必自卑,涉远必自迩".以下几项Java知识和Spring框架息息相关,不可不学(我将通过一个系 ...
- 如何学习java?Java基础知识点分享
面对未知的行业,人们的第一反应应该是:拒绝踏入.因为学习真的是一个痛苦的过程.想要真正了解一个行业,熟知一个行业,并熟练掌握某一技术,是真的需要时间和精力的.在学习Java基础知识期间,千锋小编疯狂为 ...
- 学习Spring必学的Java基础知识(1)----反射
引述要学习Spring框架的技术内幕,必须事先掌握一些基本的Java知识,正所谓"登高必自卑,涉远必自迩".以下几项Java知识和Spring框架息息相关,不可不学(我将通过一个系 ...
- java基础-学java util类库总结
JAVA基础 Util包介绍 学Java基础的工具类库java.util包.在这个包中,Java提供了一些实用的方法和数据结构.本章介绍Java的实用工具类库java.util包.在这个包中,Java ...
- Java基础知识总结(超级经典)
Java基础知识总结(超级经典) 写代码: 1,明确需求.我要做什么? 2,分析思路.我要怎么做?1,2,3. 3,确定步骤.每一个思路部分用到哪些语句,方法,和对象. 4,代码实现.用具体的java ...
随机推荐
- springboot整合quartz并持久化到数据库
首先,这里的持久化是是如果当服务器宕机时,任务还在为我们保存.并且在启动服务器之后仍然可以自动执行 一.创建quartz 建表语句mysql的,quartz 2.3.0版本 DROP TABLE IF ...
- '/'和‘/*’差异造成的No mapping found for HTTP request with URI [/springMVC/welcome.jsp] in DispatcherServlet with name 'springmvc'
在采用springMVC框架的时候所遇到的一个小问题,其中web.xml中关于servlet的配置如下: <servlet> <servlet-name>springmvc&l ...
- Oracle修改密码
1. 登陆oracle sqlplus '/as sysdba' 2. 修改密码 ALTER USER 用户名IDENTIFIED BY 要修改的密码 ; 3.解锁 alter user 用户名 ac ...
- crashpad 应用程序异常解决方案
衡量某个应用程序的稳定性的一个重要指标即它自身的崩溃率的统计,但是如何判断应用程序崩溃,且上报崩溃产生的dmp文件进行分析? google提供了一套开源的系统 Crashpad,详细了解参见 http ...
- mysql批量插入更新操作
//添加关联赠品(确定) public function addGiveGoods($ids,$child,$parent_sku_no){ $license=new LicenseModel(); ...
- Linux添加虚拟内存 && 修改Linux系统语言
Linux添加虚拟内存 首先执行free -h查看内存状况: total used free shared buff/cache available Mem: 1.8G 570M 76M 8.4M 1 ...
- Spring容器的创建原理
1.new ioc容器(AnnotationConfigApplicationContext 注解ioc) 2.refresh()方法调用 2.1 prepareRefresh()刷新前的预处理 a: ...
- 说说我当初是如何学Linux的
今天我就说说我当初是如何从一名普通桌面维护工程师,通过学习和努力转成Linux运维工程师的,以及作为Linux运维工程师需要一些什么技能和知识,希望可以帮到一些对Linux有兴趣或者想往Linux这个 ...
- 一对多关联按照一方的id查找信息的一个笛卡尔积问题
mapper中,关联的一对多,正确的结果应该是按照一方的id查找,根据映射得到的是一个一方对象,对象里嵌套这list属性,但是结果却出来了多条,在sql中实验 一方中123456789只有一条数据 多 ...
- REST接口
全名是Representational State Transfer REST是设计风格而不是标准 建议将JSON格式作为标准响应格式 -------------------------------- ...