Spring?Boot配置內(nèi)容加密實現(xiàn)敏感信息保護
在之前的系列教程中,我們已經(jīng)介紹了非常多關(guān)于Spring Boot配置文件中的各種細節(jié)用法,比如:參數(shù)間的引用、隨機數(shù)的應(yīng)用、命令行參數(shù)的使用、多環(huán)境的配置管理等等。
為什么要加密?
可能很多初學者,對于配置信息的加密并不敏感,因為開始主要接觸本地的開發(fā),對于很多安全問題并沒有太多的考慮。而現(xiàn)實中,我們的配置文件中,其實包含著大量與安全相關(guān)的敏感信息,比如:數(shù)據(jù)庫的賬號密碼、一些服務(wù)的密鑰等。這些信息一旦泄露,對于企業(yè)的重要數(shù)據(jù)資產(chǎn),那是相當危險的。 所以,對于這些配置文件中存在的敏感信息進行加密,是每個成熟開發(fā)團隊都一定會去的事。
第一步:創(chuàng)建一個基礎(chǔ)的Spring Boot項目
第二步:設(shè)計一個參數(shù)和單元測試,用來輸出這個配置信息
準備加密的配置:
datasource.password=didispace.com
用來輸出配置信息的單元測試:
@Slf4j
@SpringBootTest
public class PropertiesTest {
@Value("${datasource.password:}")
private String password;
@Test
public void test() {
log.info("datasource.password : {}", password);
}
}
執(zhí)行這個單元測試,會輸出:
2021-08-13 22:28:45.506? INFO 70405 --- [? ? ? ? ? ?main] com.didispace.chapter15.PropertiesTest? ?: datasource.password : didispace.com
這里還沒開始加密,下面我們開始引入加密的操作!
第三步:在pom.xml中引入jasypt提供的Spring Boot Starter
<dependency>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-spring-boot-starter</artifactId>
<version>3.0.3</version>
</dependency>
在插件配置中加入:
<plugin>
<groupId>com.github.ulisesbocchio</groupId>
<artifactId>jasypt-maven-plugin</artifactId>
<version>3.0.3</version>
</plugin>
第四步:在配置文件中加入加密需要使用的密碼
jasypt.encryptor.password=didispace
同時,修改要加密的內(nèi)容,用DEC()將待加密內(nèi)容包裹起來,比如:
datasource.password=DEC(didispace.com)
第五步:使用jasypt-maven-plugin插件來給DEC()包裹的內(nèi)容實現(xiàn)批量加密。
在終端中執(zhí)行下面的命令:
mvn jasypt:encrypt -Djasypt.encryptor.password=didispace
注意:這里-Djasypt.encryptor.password參數(shù)必須與配置文件中的一致,不然后面會解密失敗。
執(zhí)行之后,重新查看配置文件,可以看到,自動變成了
datasource.password=
ENC(/AL9nJENCYCh9Pfzdf2xLPsqOZ6HwNgQ3AnMybFAMeOM5GphZlOK6PxzozwtCm+Q)
jasypt.encryptor.password=didispace
其中,ENC()跟DEC()一樣都是jasypt提供的標識,分別用來標識括號內(nèi)的是加密后的內(nèi)容和待加密的內(nèi)容。
如果當前配置文件已經(jīng)都是ENC()內(nèi)容了,那么我們可以通過下面的命令來解密配置文件,查看原始信息:
mvn jasypt:decrypt -Djasypt.encryptor.password=didispace
該操作不會修改配置文件,只會在控制臺輸出解密結(jié)果,比如:
datasource.password=DEC(didispace.com)
jasypt.encryptor.password=didispace
第六步:此時,我們的配置文件中的敏感信息已經(jīng)被ENC()修飾了,再執(zhí)行一下單元測試,不出意外的話,依然可以得到之前一樣的結(jié)果:
2021-08-13 22:50:00.463? INFO 76150 --- [? ? ? ? ? ?main] com.didispace.chapter15.PropertiesTest? ?: datasource.password : didispace.com
而此時,配置文件中已經(jīng)是加密內(nèi)容了,敏感信息得到了保護。
以上就是Spring Boot配置內(nèi)容加密實現(xiàn)敏感信息保護的詳細內(nèi)容,更多關(guān)于Spring Boot配置內(nèi)容加密保護敏感信息的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
linux部署出現(xiàn)java文件操作報錯:java.io.FileNotFoundException解決辦法
這篇文章主要g介紹了linux部署出現(xiàn)java文件操作報錯:java.io.FileNotFoundException解決的相關(guān)資料,這個錯誤通常表示你的Spring Boot應(yīng)用程序無法找到指定的文本文件,需要的朋友可以參考下2023-12-12
Java?Mybatis的初始化之Mapper.xml映射文件的詳解
這篇文章主要介紹了Java?Mybatis的初始化之Mapper.xml映射文件的詳解,解析完全局配置文件后接下來就是解析Mapper文件了,它是通過XMLMapperBuilder來進行解析的2022-08-08
springboot源碼中this::selfInitialize怪異用法的含義解析
這篇文章主要介紹了springboot源碼中this::selfInitialize怪異用法的含義解析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03

