色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

Java 實現加密數據庫連接的步驟

瀏覽:66日期:2022-08-21 13:29:57

作者:月光中的污點

原文鏈接: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/

一、前言

在很多項目中,數據庫相關的配置文件內容都是以明文的形式展示的,這存在一定的安全隱患。

在開發和維護項目時,不僅要關注項目的性能,同時也要注重其安全性。

二、實現思路

我們都知道項目啟動時,Spring 容器會加載配置文件并讀取文件中的內容,那么我們可以下邊步驟操作:

通過 DES 算法加密連接數據庫的賬號和密碼并將加密后的密文寫到 db 配置文件中。

在 Spring 讀取 db 配置文件時將密文解密回明文。

三、實現編碼

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); } }}

通過上邊的工具類對連接數據庫的賬號密碼進行加密。筆者主機上連接數據庫的賬號和密碼分別是 “root” 和 “tiger”。

經過加密后得到 “WnplV/ietfQ=” 和 “xyHEykQVHqA=” 。

db.properties 配置文件完整內容如下:

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 部分內容:

<!-- <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 個步驟后按照往常操作,直接運行項目即可。

四、總結

起初,在不了解實現思路前覺得這功能很神秘和高大尚。但是,理清思路后功能實現起來就非常簡單了。

作為程序員不能被神秘的表象驚嘆而“望而卻步”,需要學會思考和理清思路,這樣才能不斷提升自身能力。

以上就是Java 實現加密數據庫連接的步驟的詳細內容,更多關于Java 實現加密數據庫連接的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 一级一级 a爱片免费视频 | 日本高清色本在线www游戏 | 亚洲欧洲日韩在线 | 国产日韩精品一区在线不卡 | 欧美三级观看 | 玖草在线观看 | 99国产精品久久久久久久日本 | 免费国产a国产片高清 | 日韩欧美国产高清在线观看 | 日韩高清欧美 | 大学生一级一片第一次免费 | 国产成人一区二区三区影院免费 | 亚洲一区二区三区免费在线观看 | 97在线免费视频观看 | 91国高清视频| 在线a毛片免费视频观看 | 加勒比一区在线 | 日韩欧美在线视频 | 欧美亚洲欧美区 | 亚洲欧美日本综合 | 亚洲精品三级 | 久久爱com | 免费国产a国产片高清不卡 免费国产不卡午夜福在线 免费国产不卡午夜福在线观看 | 国产网站免费 | 视频一区在线 | 中日韩精品视频在线观看 | 国产精品国产高清国产专区 | 国产日韩欧美综合一区二区三区 | 5x性区m免费毛片视频看看 | 亚洲一级毛片视频 | 欧美日韩亚洲综合在线一区二区 | 理论片免费午夜 | 免费v片视频在线观看视频 免费v片在线观看 | 国产萌白酱在线一区二区 | 国产特黄特色的大片观看免费视频 | 男女视频在线观看 | 亚洲社区在线 | 亚洲精品一区二区久久 | japanesetubesexfree| 一级a欧美毛片 | 久久精品国产第一区二区 |