SpringBoot yml配置敏感信息加密的實(shí)現(xiàn)
在 Spring Boot 項(xiàng)目里運(yùn)用 Jasypt 實(shí)現(xiàn)配置文件的加密。
第一步:添加依賴
要在pom.xml文件中添加 Jasypt 的依賴。
<dependency>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-spring-boot-starter</artifactId>
<version>3.0.5</version>
</dependency>
第二步:配置加密密鑰
有兩種方式可以配置加密密鑰,分別是通過環(huán)境變量和命令行參數(shù)。
環(huán)境變量方式
在application.properties或者application.yml中設(shè)置如下內(nèi)容:
jasypt.encryptor.password=${JASYPT_ENCRYPTOR_PASSWORD}
命令行參數(shù)方式
啟動應(yīng)用程序時(shí),使用以下命令添加參數(shù):
java -Djasypt.encryptor.password=your-secret-key -jar your-application.jar
第三步:生成加密值
下面是一個(gè)工具類,可用于生成加密值:
import org.jasypt.encryption.pbe.StandardPBEStringEncryptor;
import org.jasypt.encryption.pbe.config.EnvironmentPBEConfig;
public class JasyptUtils {
public static void main(String[] args) {
// 加密密鑰,實(shí)際使用時(shí)可通過環(huán)境變量或其他安全方式獲取
String password = "your-secret-key";
String plainText = "需要加密的內(nèi)容";
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);
}
}
第四步:在配置文件中使用加密值
在配置文件里按照如下格式使用加密值:
# 數(shù)據(jù)庫配置示例 spring.datasource.url=jdbc:mysql://localhost:3306/mydb spring.datasource.username=ENC(加密后的用戶名) spring.datasource.password=ENC(加密后的密碼)
第五步:驗(yàn)證配置
啟動應(yīng)用程序時(shí),要確保已經(jīng)正確設(shè)置了加密密鑰。Jasypt 會在應(yīng)用啟動時(shí)自動對加密值進(jìn)行解密。
注意事項(xiàng)
- 加密密鑰屬于敏感信息,不能硬編碼在代碼或者配置文件中。建議通過環(huán)境變量、CI/CD 工具或者 Kubernetes Secret 等安全方式來管理。
- 可以根據(jù)實(shí)際需求調(diào)整加密算法,例如使用更安全的
PBEWITHHMACSHA512ANDAES_256。 - 要妥善保管好加密密鑰,一旦丟失,將無法對已加密的內(nèi)容進(jìn)行解密。
通過上述步驟,你就能在 Spring Boot 項(xiàng)目中安全地使用 Jasypt 對配置信息進(jìn)行加密了。
到此這篇關(guān)于SpringBoot yml配置敏感信息加密的是西安的文章就介紹到這了,更多相關(guān)SpringBoot yml敏感信息加密內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringCloud使用feign調(diào)用錯(cuò)誤的問題
這篇文章主要介紹了SpringCloud使用feign調(diào)用錯(cuò)誤的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
學(xué)習(xí)Java模擬實(shí)現(xiàn)百度文檔在線瀏覽
這片文章介紹了如何使用Java模擬實(shí)現(xiàn)百度文檔在線瀏覽,文章思路清晰,需要的朋友可以參考下2015-07-07
Java 動態(tài)編譯在項(xiàng)目中的實(shí)踐分享
在 Java 中,動態(tài)編譯是指在運(yùn)行時(shí)動態(tài)地編譯 Java 源代碼,生成字節(jié)碼,并加載到 JVM 中執(zhí)行,動態(tài)編譯可以用于實(shí)現(xiàn)動態(tài)代碼生成、動態(tài)加載、插件化等功能,本文將給大家分享一下Java 動態(tài)編譯在項(xiàng)目中的實(shí)踐,感興趣的同學(xué)跟著小編一起來看看吧2023-07-07

