web项目配置listener来切换环境参数

项目部署到不同的环境上时,需要对数据库连接等参数进行切换。每次部署完成后,再逐一更改这些参数麻烦且易出错,因此想通过自动化的方式修改。
查知WEB项目启动时,首先会读取web.xml配置文件,获取到和中配置,然后将中的配置转化为键值对,作为项目的公共变量,对中的类创建监听实例。因此可以通过监听实例的方法来使项目在尝试连接数据库之前,对数据库参数进行初始化。
代码及配置如下:
(1) 在web.xml中配置listener


    com.listener.CheckConfigListener
  

(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 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)
    {
    }
}

你可能感兴趣的:(SSM,listener)