日期:2014-05-20  浏览次数:20803 次

可控制的数据库配置。。。
我现在要发送一条请求 service/?request=changeConfiguration&user=abcd&password=123&url=127.0.0.1/xxx
来变更原有的数据库配置
代码如下:Cofig.properties
Java code
DB_DRIVER=org.postgresql.Driver
DB_CONN_URL=jdbc\:postgresql\://127.0.0.1\:5432/zyzx
DB_USER=zyzx
DB_PASSWORD=zyzx

Configuration.java
Java code

    public static String DRIVER;
    public static String URL;
    public static String USER;
static{
        FileInputStream in = null;
        try{
            String propertyPath = System.getProperty("user.dir").concat(File.separator).concat("Config.properties");
            in = new FileInputStream(propertyPath);
            Properties p = new Properties();
            p.load(in);
            DRIVER = p.getProperty("DB_DRIVER");
            URL = p.getProperty("DB_CONN_URL");
                            USER = p.getProperty("DB_USER");
                       DBUtil.startPool();
                         }catch(){}....


DBUtil.java
Java code

    private static BasicDataSource ds = null;

    public static void startPool() {
        ds = new BasicDataSource();
        ds.setDriverClassName((String) Configuration.DRIVER);
        ds.setUsername((String) Configuration.USER);
        ds.setPassword((String) Configuration.PASSWORD);
        ds.setUrl((String) Configuration.URL);
                 }
             public static Connection getConnection() throws SQLException{
        return ds.getConnection();
    }
        


我要在servlet里接收请求
例如
else if("changeConfiguration".equals(request.getParamer("request"))){
  changeDB(user,password,url) //修改数据库方法 不知道怎么写
}

在线坐等大神解答。。。。

------解决方案--------------------
探讨
上面说是怕服务器挂掉,如果挂掉,会更换另一台服务器,数据库连接也会改变。。

------解决方案--------------------
Java code

    public void a() throws FileNotFoundException, IOException{
        String path = "/config.properties";
        Properties p = new Properties();
        p.setProperty("DB_DRIVER", "");
        p.setProperty("DB_CONN_URL", "");
        p.setProperty("DB_USER", "");
        p.setProperty("DB_PASSWORD", "");
        p.store(new FileOutputStream(path), null);
    }