项目部署到不同的环境上时,需要对数据库连接等参数进行切换。每次部署完成后,再逐一更改这些参数麻烦且易出错,因此想通过自动化的方式修改。
查知WEB项目启动时,首先会读取web.xml配置文件,获取到和中配置,然后将中的配置转化为键值对,作为项目的公共变量,对中的类创建监听实例。因此可以通过监听实例的方法来使项目在尝试连接数据库之前,对数据库参数进行初始化。
代码及配置如下:
(1) 在web.xml中配置listener
<listener>
<listener-class>com.listener.CheckConfigListener</listener-class>
</listener>
(2) 添加listener类。该方法通过参数test_env/env来切换类生产环境或者生产环境的数据库参数。其中getProp和setProp分别是读写对应配置文件参数的方法。
package com.listener;
import com.util.ReaderProp;
import javax.servlet.http.HttpSessionEvent;
import javax.servlet.http.HttpSessionListener;
import java.util.HashMap;
import java.util.Map;
public class CheckConfigListener implements HttpSessionListener
{
static {
//读取环境变量environment,通过environment值来切换数据库参数
String environment = ReaderProp.getProp("environment", "httpAddress.properties");
Map<String,String> testEnvProp = new HashMap<>();
if(environment.equals("test_env")){
testEnvProp.put("dbType","mysql");
testEnvProp.put("driverClassName","com.mysql.jdbc.Driver");
testEnvProp.put("url","jdbc:mysql://xxx.xxx.xxx.xxx:3306/hpcdbs?characterEncoding=utf-8");
testEnvProp.put("characterEncoding","utf-8");
testEnvProp.put("mysql_username","xxxxx");
testEnvProp.put("mysql_password","xxxxx");
}else{
testEnvProp.put("dbType","mysql");
testEnvProp.put("driverClassName","com.mysql.jdbc.Driver");
testEnvProp.put("url","jdbc:mysql://xxx.xxx.xxx.xxx:3306/hpcdbs?characterEncoding=utf-8");
testEnvProp.put("characterEncoding","utf-8");
testEnvProp.put("mysql_username","xxxxx");
testEnvProp.put("mysql_password","xxxxx");
}
ReaderProp.setProp(testEnvProp,"jdbc.properties");
}
@Override
public void sessionCreated(HttpSessionEvent arg0) {
}
@Override
public void sessionDestroyed(HttpSessionEvent se)
{
}
}