Spring Boot加密配置文件特殊內(nèi)容的示例代碼詳解
有時(shí)安全不得不考慮,看看新聞泄漏風(fēng)波事件就知道了我們?cè)谟肧pring boot進(jìn)行開發(fā)時(shí),經(jīng)常要配置很多外置參數(shù)ftp、數(shù)據(jù)庫(kù)連接信息、支付信息等敏感隱私信息,如下
這不太好,特別是互聯(lián)網(wǎng)應(yīng)用,應(yīng)該用加密的方式比較安全,有點(diǎn)類似一些應(yīng)用如電商、公安、安檢平臺(tái)、滾動(dòng)式大屏中獎(jiǎng)信息等顯示身份證號(hào)和手機(jī)號(hào)都是前幾位4109128*********和158*******。那就把圖中的明文改造下1. 引入加密包,可選,要是自己實(shí)現(xiàn)加解密算法,就不需要引入第三方加解密庫(kù)
<dependency> <groupId>com.github.ulisesbocchio</groupId> <artifactId>jasypt-spring-boot-starter</artifactId> <version>3.0.2</version> </dependency>
2. 加密敏感內(nèi)容,然后填充配置文件加密代碼:
BasicTextEncryptor textEncryptor = new BasicTextEncryptor();
textEncryptor.setPassword("company");
String name = textEncryptor.encrypt("root");
String password = textEncryptor.encrypt("cstorfs");
System.out.println("數(shù)據(jù)庫(kù)用戶名加密后:"+name);
System.out.println("數(shù)據(jù)庫(kù)密碼加密后:"+password);
輸出加密后的效果
把這兩個(gè)值對(duì)應(yīng)的填充到數(shù)據(jù)庫(kù)用戶名和密碼
3. 編寫配置類就是Spring里的標(biāo)有@Configuration注解的類,然后解密配置文件里的數(shù)據(jù)庫(kù)用戶名和密碼(就是上圖中的敏感屬性字段)
4. 編寫測(cè)試案例只寫核心代碼
// 我使用的最新版Springboot2.3.0(放棄1版本)啟動(dòng)后,不放心的話可以測(cè)試數(shù)據(jù)庫(kù)是否連接正常
UserMapper userMapper = applicationContext.getBean(UserMapper.class);
Example example = new Example(User.class);
example.createCriteria().andEqualTo("username", "dongguangming");
List<User> userList = userMapper.selectByExample(example);
if (userList.size() > 0) {
User user = userList.get(0);
logger.info("數(shù)據(jù)庫(kù)連接正常,從用戶表取用戶名是donggguangming的數(shù)據(jù),用戶:" + user);
}
輸出效果:
ok,就是這效果!??!注意,加解密算法沒(méi)有強(qiáng)制要求,可以自己寫,敏感信息(ftp、email、數(shù)據(jù)庫(kù)連接信息、支付支付寶微信等)也可以接著加,用的時(shí)候把它解密出現(xiàn)就行
總結(jié)
到此這篇關(guān)于Spring Boot加密配置文件特殊內(nèi)容的示例代碼詳解的文章就介紹到這了,更多相關(guān)spring boot加密配置文件特殊內(nèi)容內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
spring和quartz整合,并簡(jiǎn)單調(diào)用(實(shí)例講解)
下面小編就為大家?guī)?lái)一篇spring和quartz整合,并簡(jiǎn)單調(diào)用(實(shí)例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07
Springboot利用Redis實(shí)現(xiàn)接口冪等性攔截
這篇文章主要為大家介紹了Springboot如何利用Redis實(shí)現(xiàn)接口冪等性攔截。本文將通過(guò)自定義注解+redis+攔截器+MD5?實(shí)現(xiàn),感興趣的可以了解一下2022-06-06
maven為MANIFEST.MF文件添加內(nèi)容的方法
這篇文章主要介紹了maven為MANIFEST.MF文件添加內(nèi)容的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
詳解Maven POM(項(xiàng)目對(duì)象模型)
這篇文章主要介紹了Maven POM(項(xiàng)目對(duì)象模型)的相關(guān)資料,文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07
Java實(shí)現(xiàn)游戲飛機(jī)大戰(zhàn)-III的示例代碼
這篇文章主要為大家介紹了如何利用Java實(shí)現(xiàn)經(jīng)典的游戲之飛機(jī)大戰(zhàn),文中采用了swing技術(shù)進(jìn)行了界面化處理,感興趣的小伙伴可以動(dòng)手試一試2022-02-02

