springboot 整合druid數(shù)據(jù)庫(kù)密碼加密功能的實(shí)現(xiàn)代碼
在之前給大家介紹過(guò)Springboot Druid 自定義加密數(shù)據(jù)庫(kù)密碼的幾種方案,感興趣的朋友可以點(diǎn)擊查看下,今天通過(guò)本文給大家介紹springboot 整合druid數(shù)據(jù)庫(kù)密碼加密功能,具體內(nèi)容如下所示:
1.依賴(lài)引入
<dependency><groupId>com.alibaba</groupId><artifactId>druid-spring-boot-starter</artifactId><version>1.1.21</version></dependency>
2.密碼加密處理
public static void main(String[] args) throws Exception { String password = 'Aq6vD!puWbk'; System.out.println('明文密碼: ' + password); String[] keyPair = ConfigTools.genKeyPair(512); //私鑰 String privateKey = keyPair[0]; //公鑰 String publicKey = keyPair[1]; //用私鑰加密后的密文 password = ConfigTools.encrypt(privateKey, password); System.out.println('privateKey:' + privateKey); System.out.println('publicKey:' + publicKey); System.out.println('password:' + password); String decryptPassword = ConfigTools.decrypt(publicKey, password); System.out.println('解密后:' + decryptPassword);}
3.yml配置文件修改connectionProperties需要注意,其他版本有connection-properties和connect-properties,注意區(qū)分
datasource: type: com.alibaba.druid.pool.DruidDataSource # 特別注意:java 9以后需要將com.mysql.jdbc.Driver 改為 com.mysql.cj.jdbc.Driver即可 # 否則報(bào)錯(cuò):Loading class `com.mysql.jdbc.Driver’. This is deprecated. driver-class-name: com.mysql.cj.jdbc.Driver druid: #基本屬性 url: jdbc:mysql://1******:3306/**?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=Asia/Shanghai username: admin password: Qh0VAjlS/LVbsAFSAFsdf24jJ7rggMNsnvJex3x1mkUKxPd2bofuAR6DtjCV20M4n2DWc5SLZmkzgjvG3Elx1g== #此處需要注意,其他版本有connection-properties和connect-properties,注意區(qū)分 connectionProperties: config.decrypt=true;config.decrypt.key=${publicKey}; filter: config: enabled: true # 啟動(dòng)ConfigFilter #配置初始化大小/最小/最大[僅用于測(cè)試,生產(chǎn)環(huán)境需要修改] initial-size: 5 min-idle: 5 max-active: 20 #獲取連接等待超時(shí)時(shí)間 max-wait: 60000 #間隔多久進(jìn)行一次檢測(cè),檢測(cè)需要關(guān)閉的空閑連接 time-between-eviction-runs-millis: 10000 #一個(gè)連接在池中最小生存的時(shí)間 min-evictable-idle-time-millis: 300000 #指定獲取連接時(shí)連接校驗(yàn)的sql查詢(xún)語(yǔ)句 validation-query: SELECT ’x’ #驗(yàn)證連接的有效性 test-while-idle: true #獲取連接時(shí)候驗(yàn)證,會(huì)影響性能(不建議true) test-on-borrow: false #打開(kāi)PSCache,并指定每個(gè)連接上PSCache的大小。oracle設(shè)為true,mysql設(shè)為false。分庫(kù)分表較多推薦設(shè)置為false pool-prepared-statements: false max-pool-prepared-statement-per-connection-size: 20publicKey: MFwwDQYJKoZIhafwqfDSAwAwSAJBAIG3LgXwadfgferwbWdkGNDzgrjfSWfrBjJ2X+m9lajH7yGPeE/vLs4hdtr1RCITBKJeevZpwZ0DBLctVS6Dc0CAwEAAQ==
到此這篇關(guān)于springboot 整合druid數(shù)據(jù)庫(kù)密碼加密功能的實(shí)現(xiàn)代碼的文章就介紹到這了,更多相關(guān)springboot 整合druid密碼加密內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 基于javaweb+jsp實(shí)現(xiàn)學(xué)生宿舍管理系統(tǒng)2. 如何封裝一個(gè)Ajax函數(shù)3. ASP.NET MVC實(shí)現(xiàn)樹(shù)形導(dǎo)航菜單4. 多級(jí)聯(lián)動(dòng)下拉選擇框,動(dòng)態(tài)獲取下一級(jí)5. jsp網(wǎng)頁(yè)實(shí)現(xiàn)貪吃蛇小游戲6. Ajax常用封裝庫(kù)——Axios的使用7. jsp+servlet簡(jiǎn)單實(shí)現(xiàn)上傳文件功能(保存目錄改進(jìn))8. CSS Hack大全-教你如何區(qū)分出IE6-IE10、FireFox、Chrome、Opera9. 怎樣打開(kāi)XML文件?xml文件如何打開(kāi)?10. Python數(shù)據(jù)分析JupyterNotebook3魔法命令詳解及示例
