SpringBoot yml配置敏感信息加密的實現
在 Spring Boot 項目里運用 Jasypt 實現配置文件的加密。
第一步:添加依賴
要在pom.xml文件中添加 Jasypt 的依賴。
<dependency>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-spring-boot-starter</artifactId>
<version>3.0.5</version>
</dependency>
第二步:配置加密密鑰
有兩種方式可以配置加密密鑰,分別是通過環(huán)境變量和命令行參數。
環(huán)境變量方式
在application.properties或者application.yml中設置如下內容:
jasypt.encryptor.password=${JASYPT_ENCRYPTOR_PASSWORD}
命令行參數方式
啟動應用程序時,使用以下命令添加參數:
java -Djasypt.encryptor.password=your-secret-key -jar your-application.jar
第三步:生成加密值
下面是一個工具類,可用于生成加密值:
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;
import org.jasypt.encryption.pbe.config.EnvironmentPBEConfig;
public class JasyptUtils {
public static void main(String[] args) {
// 加密密鑰,實際使用時可通過環(huán)境變量或其他安全方式獲取
String password = "your-secret-key";
String plainText = "需要加密的內容";
StandardPBEStringEncryptor encryptor = new StandardPBEStringEncryptor();
EnvironmentPBEConfig config = new EnvironmentPBEConfig();
config.setAlgorithm("PBEWithMD5AndDES");
config.setPassword(password);
encryptor.setConfig(config);
String encryptedText = encryptor.encrypt(plainText);
String decryptedText = encryptor.decrypt(encryptedText);
System.out.println("原始文本: " + plainText);
System.out.println("加密后: ENC(" + encryptedText + ")");
System.out.println("解密后: " + decryptedText);
}
}
第四步:在配置文件中使用加密值
在配置文件里按照如下格式使用加密值:
# 數據庫配置示例 spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=ENC(加密后的用戶名) spring.datasource.password=ENC(加密后的密碼)
第五步:驗證配置
啟動應用程序時,要確保已經正確設置了加密密鑰。Jasypt 會在應用啟動時自動對加密值進行解密。
注意事項
- 加密密鑰屬于敏感信息,不能硬編碼在代碼或者配置文件中。建議通過環(huán)境變量、CI/CD 工具或者 Kubernetes Secret 等安全方式來管理。
- 可以根據實際需求調整加密算法,例如使用更安全的
PBEWITHHMACSHA512ANDAES_256。 - 要妥善保管好加密密鑰,一旦丟失,將無法對已加密的內容進行解密。
通過上述步驟,你就能在 Spring Boot 項目中安全地使用 Jasypt 對配置信息進行加密了。
到此這篇關于SpringBoot yml配置敏感信息加密的是西安的文章就介紹到這了,更多相關SpringBoot yml敏感信息加密內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

