1. 程式人生 > 其它 >使用Druid資料庫連線池,配置ConfigFilter對資料庫密碼加密

使用Druid資料庫連線池,配置ConfigFilter對資料庫密碼加密

ConfigFilter的作用包括:

  • 從配置檔案中讀取配置
  • 從遠端http檔案中讀取配置
  • 為資料庫密碼提供加密功能

1.配置ConfigFilter

1.1配置檔案從本地檔案系統中讀取

  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
  2. init-method="init" destroy-method="close">
  3. <property name="filters" value="config" />
  4. <property name="connectionProperties" value="config.file=file:///home/admin/druid-pool.properties" />
  5. </bean>

1.2配置檔案從遠端http伺服器中讀取

  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
  2. init-method="init" destroy-method="close">
  3. <property name="filters" value="config" />
  4. <property name="connectionProperties" value="config.file=http://127.0.0.1/druid-pool.properties" />
  5. </bean>

這種配置方式,使得一個應用叢集中,多個例項可以從同一個地方讀取配置,集中配置,集中修改,部署更簡單。

1.3通過jvm啟動引數來使用ConfigFilter

DruidDataSource支援jvm啟動引數配置filters,所以你可以:

java -Ddruid.filters=config ....

2資料庫密碼加密

資料庫密碼直接寫在配置中,對運維安全來說,是一個很大的挑戰。Druid為此提供一種資料庫密碼加密的手段ConfigFilter。

2.1執行命令加密資料庫密碼

在命令列中執行如下命令:

java -cp druid-1.0.16.jar com.alibaba.druid.filter.config.ConfigTools you_password

輸出

  1. privateKey:MIIBVgIBADANBgkqhkiG9w0BAQEFAASCAUAwggE8AgEAAkEA6+4avFnQKP+O7bu5YnxWoOZjv3no4aFV558HTPDoXs6EGD0HP7RzzhGPOKmpLQ1BbA5viSht+aDdaxXp6SvtMQIDAQABAkAeQt4fBo4SlCTrDUcMANLDtIlax/I87oqsONOg5M2JS0jNSbZuAXDv7/YEGEtMKuIESBZh7pvVG8FV531/fyOZAiEA+POkE+QwVbUfGyeugR6IGvnt4yeOwkC3bUoATScsN98CIQDynBXC8YngDNwZ62QPX+ONpqCel6g8NO9VKC+ETaS87wIhAKRouxZL38PqfqV/WlZ5ZGd0YS9gA360IK8zbOmHEkO/AiEAsES3iuvzQNYXFL3x9Tm2GzT1fkSx9wx+12BbJcVD7AECIQCD3Tv9S+AgRhQoNcuaSDNluVrL/B/wOmJRLqaOVJLQGg==
  2. publicKey:MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBAOvuGrxZ0Cj/ju27uWJ8VqDmY7956OGhVeefB0zw6F7OhBg9Bz+0c84RjzipqS0NQWwOb4kobfmg3WsV6ekr7TECAwEAAQ==
  3. password:PNak4Yui0+2Ft6JSoKBsgNPl+A033rdLhFw+L0np1o+HDRrCo9VkCuiiXviEMYwUgpHZUFxb2FpE0YmSguuRww==

輸入你的資料庫密碼,輸出的是加密後的結果。

2.2配置資料來源,提示Druid資料來源需要對資料庫密碼進行解密。

  1. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource"
  2. init-method="init" destroy-method="close">
  3. <property name="url" value="jdbc:derby:memory:spring-test;create=true" />
  4. <property name="username" value="sa" />
  5. <property name="password" value="${password}" />
  6. <property name="filters" value="config" />
  7. <property name="connectionProperties" value="config.decrypt=true;config.decrypt.key=${publickey}" />
  8. </bean>

2.3配置引數,讓ConfigFilter解密密碼

有三種方式配置:

  1. 可以在配置檔案my.properties中指定config.decrypt=true
  2. 也可以在DruidDataSource的ConnectionProperties中指定config.decrypt=true
  3. 也可以在jvm啟動引數中指定-Ddruid.config.decrypt=true

以下示例是我在開發專案中用Druid資料庫連線池所寫:

  1. @Bean
  2. protected DataSource dataSource() {
  3. DruidDataSource dataSource = new DruidDataSource();
  4. try {
  5. // 1.
  6. // dataSource.setFilters("config");
  7. // String connectionProperties =
  8. // "config.file=classpath:mysql_db.prorerties";
  9. // dataSource.setConnectionProperties(connectionProperties);
  10. // 2。使用Druid資料來源
  11. try {
  12. Properties properties = new Properties();
  13. InputStream inStream = getClass().getResourceAsStream("/mysql_db.prorerties");
  14. properties.load(inStream);
  15. dataSource.setFilters("config");
  16. dataSource.setUsername(properties.getProperty("username"));
  17. dataSource.setPassword(properties.getProperty("password"));
  18. dataSource.setDriverClassName(properties.getProperty("driverClassName"));
  19. dataSource.setUrl(properties.getProperty("url"));
  20. String publickey = properties.getProperty("publickey");
  21. String connectionProperties = "config.decrypt=true;config.decrypt.key=" + publickey;
  22. dataSource.setConnectionProperties(connectionProperties);
  23. } catch (IOException e) {
  24. e.printStackTrace();
  25. }
  26. } catch (SQLException e) {
  27. e.printStackTrace();
  28. }
  29. return dataSource;
  30. }
  1. #2Druid資料來源
  2. publickey=MFwwDQYJKoZIhvcNAQEBBQADSwAwSAJBANDHoaPpziat/FYuWot6kJh5Hyz9DnOzOhxJImXgsHr/OVYGCRTlOuj8m5fLs9kS0hjn46lvsCXOn5+y2/TrPB0CAwEAAQ==
  3. username=root
  4. password=jvagl79+aZg6U6448zsZnRrHgVorbjoL5MEQ6c2r9R2K+H4Wnpix9z5m9Ig1yvFp/6HqB+vGr5xRLC8HDYe2Ag==
  5. driverClassName=com.mysql.jdbc.Driver
  6. url=jdbc:mysql://127.0.0.1:3306/demo

當出現以下異常時:

org.springframework.transaction.CannotCreateTransactionException: Could not open JDBC Connection for transaction; nested exception is java.lang.IllegalArgumentException: Failed to decrypt.

請仔細檢查加密後的密碼、publickey是否是命令列中輸出的相同。