Java 實(shí)現(xiàn)加密數(shù)據(jù)庫(kù)連接的步驟
作者:月光中的污點(diǎn)
原文鏈接:https://www.extlight.com/2017/12/16/Java-%E5%AE%9E%E7%8E%B0%E5%8A%A0%E5%AF%86%E6%95%B0%E6%8D%AE%E5%BA%93%E8%BF%9E%E6%8E%A5/
一、前言
在很多項(xiàng)目中,數(shù)據(jù)庫(kù)相關(guān)的配置文件內(nèi)容都是以明文的形式展示的,這存在一定的安全隱患。
在開發(fā)和維護(hù)項(xiàng)目時(shí),不僅要關(guān)注項(xiàng)目的性能,同時(shí)也要注重其安全性。
二、實(shí)現(xiàn)思路
我們都知道項(xiàng)目啟動(dòng)時(shí),Spring 容器會(huì)加載配置文件并讀取文件中的內(nèi)容,那么我們可以下邊步驟操作:
通過 DES 算法加密連接數(shù)據(jù)庫(kù)的賬號(hào)和密碼并將加密后的密文寫到 db 配置文件中。
在 Spring 讀取 db 配置文件時(shí)將密文解密回明文。
三、實(shí)現(xiàn)編碼
3.1 加密工具類
DESUtil 類:
public class DESUtil { private static Key key; private static String KEY_STR = 'myKey'; private static String CHARSETNAME = 'UTF-8'; private static String ALGORITHM = 'DES'; static { try { KeyGenerator generator = KeyGenerator.getInstance(ALGORITHM); SecureRandom secureRandom = SecureRandom.getInstance('SHA1PRNG'); secureRandom.setSeed(KEY_STR.getBytes()); generator.init(secureRandom); key = generator.generateKey(); generator = null; } catch (Exception e) { throw new RuntimeException(e); } } /** * 加密 * @param str * @return */ public static String getEncryptString(String str) { BASE64Encoder base64encoder = new BASE64Encoder(); try { byte[] bytes = str.getBytes(CHARSETNAME); Cipher cipher = Cipher.getInstance(ALGORITHM); cipher.init(Cipher.ENCRYPT_MODE, key); byte[] doFinal = cipher.doFinal(bytes); return base64encoder.encode(doFinal); } catch (Exception e) { // TODO: handle exception throw new RuntimeException(e); } } /** * 解密 * @param str * @return */ public static String getDecryptString(String str) { BASE64Decoder base64decoder = new BASE64Decoder(); try { byte[] bytes = base64decoder.decodeBuffer(str); Cipher cipher = Cipher.getInstance(ALGORITHM); cipher.init(Cipher.DECRYPT_MODE, key); byte[] doFinal = cipher.doFinal(bytes); return new String(doFinal, CHARSETNAME); } catch (Exception e) { throw new RuntimeException(e); } }}
通過上邊的工具類對(duì)連接數(shù)據(jù)庫(kù)的賬號(hào)密碼進(jìn)行加密。筆者主機(jī)上連接數(shù)據(jù)庫(kù)的賬號(hào)和密碼分別是 “root” 和 “tiger”。
經(jīng)過加密后得到 “WnplV/ietfQ=” 和 “xyHEykQVHqA=” 。
db.properties 配置文件完整內(nèi)容如下:
jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://127.0.0.1:3306/test?characterEncoding=utf-8&allowMultiQueries=true&serverTimezone=UTCjdbc.username=WnplV/ietfQ=jdbc.password=xyHEykQVHqA=
3.2 配置文件解析類
EncryptPropertyPlaceholderConfigurer 類:
public class EncryptPropertyPlaceholderConfigurer extends PropertyPlaceholderConfigurer { // 需要解密的字段 private String[] encryptPropNames = { 'jdbc.username', 'jdbc.password' }; @Override protected String convertProperty(String propertyName, String propertyValue) { if (isEncryptProp(propertyName)) { // 解密 String decryptValue = DESUtil.getDecryptString(propertyValue); return decryptValue; } else { return propertyValue; } } private boolean isEncryptProp(String propertyName) { for (String encryptpropertyName : encryptPropNames) { if (encryptpropertyName.equals(propertyName)) return true; } return false; }}
3.3 Spring 配置文件
applicationContext-mybatis.xml 部分內(nèi)容:
<!-- <context:property-placeholder location='classpath:*.properties'/> --> <bean class='com.light.ac.common.configuration.EncryptPropertyPlaceholderConfigurer'> <property name='locations'> <list> <value>classpath:db.properties</value> </list> </property> <property name='fileEncoding' value='UTF-8'/></bean>
未加密明文前,使用的是 <context:property-placeholder /> 加載 db 配置文件。
加密明文后,使用配置文件解析類加載 db 配置文件。
完成上述 3 個(gè)步驟后按照往常操作,直接運(yùn)行項(xiàng)目即可。
四、總結(jié)
起初,在不了解實(shí)現(xiàn)思路前覺得這功能很神秘和高大尚。但是,理清思路后功能實(shí)現(xiàn)起來就非常簡(jiǎn)單了。
作為程序員不能被神秘的表象驚嘆而“望而卻步”,需要學(xué)會(huì)思考和理清思路,這樣才能不斷提升自身能力。
以上就是Java 實(shí)現(xiàn)加密數(shù)據(jù)庫(kù)連接的步驟的詳細(xì)內(nèi)容,更多關(guān)于Java 實(shí)現(xiàn)加密數(shù)據(jù)庫(kù)連接的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. asp讀取xml文件和記數(shù)2. 多個(gè)SpringBoot項(xiàng)目采用redis實(shí)現(xiàn)Session共享功能3. 簡(jiǎn)體中文轉(zhuǎn)換為繁體中文的PHP函數(shù)4. PHP實(shí)現(xiàn)基本留言板功能原理與步驟詳解5. 每日六道java新手入門面試題,通往自由的道路第二天6. CSS自定義滾動(dòng)條樣式案例詳解7. 讓你的PHP同時(shí)支持GIF、png、JPEG8. vue 驗(yàn)證兩次輸入的密碼是否一致的方法示例9. python利用opencv實(shí)現(xiàn)顏色檢測(cè)10. ie6,ie7,ie8完美支持position:fixed的終極解決方案
