SpringBoot項目配置數據庫密碼加密相關代碼
一、說明
我們在寫Springboot項目時候,配置文件中需要配置數據庫連接,用戶名和密碼都是明文配置的。這樣做很不安全,容易密碼泄露。
二、加密方案
1、加密方案有好多種,下來介紹一種本人用的,比較簡單的加密方法。
2、使用說明:
使用密碼加密工具類,生成加密后的字符串,配置到你的項目配置文件中,項目啟動后,springboot項目會根據你寫的解密方法去自行解密,從而鏈接到你的數據庫。
三、相關代碼
1、application.yml
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/patient?useUnicode=true&characterEncoding=utf-8&useSSL=false&serverTimezone=UTC
username: test
password: oiWRKCcmZH/pQes5KH03kgVSHza7OK/G
jpa:
hibernate:
ddl-auto: update
show-sql: true2、密碼加密工具類
package com.jianqi.HL7Service.config;
import org.jasypt.properties.PropertyValueEncryptionUtils;
import org.jasypt.util.text.BasicTextEncryptor;
public final class JasyptEncryptorUtils {
private static final String salt = "test666";
private static BasicTextEncryptor basicTextEncryptor = new BasicTextEncryptor();
static {
basicTextEncryptor.setPassword(salt);
}
private JasyptEncryptorUtils(){}
/**
* 明文加密
* @param plaintext
* @return
*/
public static String encode(String plaintext){
System.out.println("明文字符串:" + plaintext);
String ciphertext = basicTextEncryptor.encrypt(plaintext);
return ciphertext;
}
/**
* 解密
* @param ciphertext
* @return
*/
public static String decode(String ciphertext){
ciphertext = "ENC(" + ciphertext + ")";
if (PropertyValueEncryptionUtils.isEncryptedValue(ciphertext)){
String plaintext = PropertyValueEncryptionUtils.decrypt(ciphertext,basicTextEncryptor);
return plaintext;
}
System.out.println("解密失敗");
return "";
}
public static void main(String[] args) {
// 需要加密的明文
String plaintext = "patient113";
// 加密明文
String encryptedText = JasyptEncryptorUtils.encode(plaintext);
System.out.println("加密后字符串:" + encryptedText);
// 解密密文
String decryptedText = JasyptEncryptorUtils.decode(encryptedText);
System.out.println("解密后的字符串:" + decryptedText);
}
}
3、數據庫配置類
package com.jianqi.HL7Service.config;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.jpa.repository.config.EnableJpaRepositories;
import org.springframework.transaction.annotation.EnableTransactionManagement;
import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.orm.jpa.JpaTransactionManager;
import org.springframework.boot.jdbc.DataSourceBuilder;
import javax.sql.DataSource;
@Configuration
@EnableJpaRepositories(basePackages = "com.jianqi.HL7Service.repository")
@EnableTransactionManagement
public class DatabaseConfig {
@Value("${spring.datasource.url}")
private String dbUrl;
@Value("${spring.datasource.username}")
private String dbUsername;
@Value("${spring.datasource.password}")
private String dbEncryptedPassword;
@Bean
public DataSource dataSource() {
// 使用 JasyptEncryptorUtils 解密數據庫密碼
String dbPassword = JasyptEncryptorUtils.decode(dbEncryptedPassword);
return DataSourceBuilder.create()
.url(dbUrl)
.username(dbUsername)
.password(dbPassword)
.build();
}
@Bean
public PlatformTransactionManager transactionManager() {
JpaTransactionManager transactionManager = new JpaTransactionManager();
transactionManager.setDataSource(dataSource());
return transactionManager;
}
}總結
到此這篇關于SpringBoot項目配置數據庫密碼加密的文章就介紹到這了,更多相關SpringBoot配置數據庫密碼加密內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Java中Mybatis,SpringMVC,Spring的介紹及聯(lián)系
這篇文章主要為大家詳細介紹了Java中Mybatis,SpringMVC,Spring的介紹及聯(lián)系,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10
SpringBoot之使用Redis實現分布式鎖(秒殺系統(tǒng))
這篇文章主要介紹了SpringBoot之使用Redis實現分布式鎖(秒殺系統(tǒng)),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04
用Java連接sqlserver數據庫時候幾個jar包的區(qū)別分析
這篇文章主要介紹了用Java連接sqlserver數據庫時候幾個jar包的區(qū)別分析,需要的朋友可以參考下2014-10-10
springboot2.2 集成 activity6實現請假流程(示例詳解)
這篇文章主要介紹了springboot2.2 集成 activity6實現請假完整流程示例詳解,本文通過示例代碼圖文相結合給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07

