Spring Boot加密配置文件特殊內(nèi)容的示例代碼詳解
有時(shí)安全不得不考慮,看看新聞泄漏風(fēng)波事件就知道了我們?cè)谟肧pring boot進(jìn)行開(kāi)發(fā)時(shí),經(jīng)常要配置很多外置參數(shù)ftp、數(shù)據(jù)庫(kù)連接信息、支付信息等敏感隱私信息,如下
這不太好,特別是互聯(lián)網(wǎng)應(yīng)用,應(yīng)該用加密的方式比較安全,有點(diǎn)類(lèi)似一些應(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ù)用戶(hù)名加密后:'+name);System.out.println('數(shù)據(jù)庫(kù)密碼加密后:'+password);
輸出加密后的效果
把這兩個(gè)值對(duì)應(yīng)的填充到數(shù)據(jù)庫(kù)用戶(hù)名和密碼
3. 編寫(xiě)配置類(lèi)就是Spring里的標(biāo)有@Configuration注解的類(lèi),然后解密配置文件里的數(shù)據(jù)庫(kù)用戶(hù)名和密碼(就是上圖中的敏感屬性字段)
4. 編寫(xiě)測(cè)試案例只寫(xiě)核心代碼
// 我使用的最新版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ù)連接正常,從用戶(hù)表取用戶(hù)名是donggguangming的數(shù)據(jù),用戶(hù):' + user);}
輸出效果:
ok,就是這效果!!!注意,加解密算法沒(méi)有強(qiáng)制要求,可以自己寫(xiě),敏感信息(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)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. jstl 字符串處理函數(shù)2. JSP動(dòng)態(tài)網(wǎng)頁(yè)開(kāi)發(fā)原理詳解3. XHTML 1.0:標(biāo)記新的開(kāi)端4. Vue中使用Echarts儀表盤(pán)展示實(shí)時(shí)數(shù)據(jù)的實(shí)現(xiàn)5. 深入理解JavaScript中的Base64編碼字符串6. java 字符串轉(zhuǎn)化為字符數(shù)組的3種實(shí)現(xiàn)案例7. JSP頁(yè)面的靜態(tài)包含和動(dòng)態(tài)包含使用方法8. WAP建站W(wǎng)ML語(yǔ)言語(yǔ)法基礎(chǔ)教程第1/6頁(yè)9. 基于python實(shí)現(xiàn)判斷字符串是否數(shù)字算法10. PHP擴(kuò)展之URL編碼、解碼及解析——URLs
