博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
druid数据源的加密解密工具
阅读量:5101 次
发布时间:2019-06-13

本文共 2549 字,大约阅读时间需要 8 分钟。

数据库得加密

先来一个网上大多数的教程吧,一个比较好的教程,如下、

 

 

jar包版本:druid-1.0.13.jar

1. 加密,用以下命令将用户名和密码加密

cmd命令行执行 java -cp D:/druid-1.0.13.jar com.alibaba.druid.filter.config.ConfigTools 用户名/密码

得到密文:

f0PSl0Lzxh6CxzuFIdEg+wVx045fSE2VtUP45G9HH2cjVQnmGGgcK5CLzNUJoR6tGwRO44h74OxrBWuDzWC8jg==

2.用户名解密:

ackage com.heli.core.user.common; import com.alibaba.druid.filter.config.ConfigTools; import com.alibaba.druid.pool.DruidDataSource; /** * 用来解密配置中的密文(重点配置,在这里扩展用户名的解密) * setUsername(name) 方法对应xml中的一个property属性,password默认加密不需要重写, * 还可以加密url 重写setUrl(url) */ @SuppressWarnings("all") public class DecryptDruidSource extends DruidDataSource{ @Override public void setUsername(String username) { try { username = ConfigTools.decrypt(username); } catch (Exception e) { e.printStackTrace(); } super.setUsername(username); } }

3.spring-database.xml中数据库连接的配置

4.数据库配置文件:

3.user.properties中#mysqlusername=f0PSl0Lzxh6CxzuFIdEg+wVx045fSE2VtUP45G9HH2cjVQnmGGgcK5CLzNUJoR6tGwRO44h74OxrBWuDzWC8jg==password=f0PSl0Lzxh6CxzuFIdEg+wVx045fSE2VtUP45G9HH2cjVQnmGGgcK5CLzNUJoR6tGwRO44h74OxrBWuDzWC8jg==url=jdbc:mysql://192.168.1.194/user?characterEncoding=utf-8driver=com.mysql.jdbc.DriverinitialSize=5minIdle=5maxActive=20maxWait=60000timeBetweenEvictionRunsMillis=60000minEvictableIdleTimeMillis=30000validationQuery=SELECT 1testWhileIdle=truetestOnBorrow=truetestOnReturn=truefilters=stat,log4jremoveAbandoned=trueremoveAbandonedTimeout=1200logAbandoned=true 但是上面那个教程有个问题,在才cmd下的加密时一个随时在变的,我只有在工程里写下如下文件,才能进行加密以及解密
1 package test; 2  3 import org.junit.Test; 4  5 import com.alibaba.druid.filter.config.ConfigTools; 6  7 public class DecryptDruid { 8     /** 9      * 对文字进行解密10      * @throws Exception11      */12     @Test13     public  void testDecrypt() throws Exception {14         //解密15         String word="MMUcTIwe+HMRBUYAVqdozWhxSB+rjY/HIBo08LsxlPJ/ocVXrvcKPwaMgWEKkApeDylU8RGPOAqsjsNy7Xg+fQ==";16         String decryptword = ConfigTools.decrypt(word);17         System.out.println(decryptword);18     }19     /**20      * 文字进行加密21      * @throws Exception 22      */23     @Test24     public void testEncrypt() throws Exception25     {26         //加密27         String password ="xxxxxxx";28         String encryptword = ConfigTools.encrypt(password);29         System.out.println(encryptword);30         31     }32 }

用上面弄出来的密码才是好的,不然密码不对

 

 

转载于:https://www.cnblogs.com/renboqie/p/5665523.html

你可能感兴趣的文章
回调没用,加上iframe提交表单
查看>>
(安卓)一般安卓开始界面 Loding 跳转 实例 ---亲测!
查看>>
Mysql 索引优化 - 1
查看>>
LeetCode(3) || Median of Two Sorted Arrays
查看>>
大话文本检测经典模型:EAST
查看>>
文本主题模型之LDA(一) LDA基础
查看>>
linux基础命令-chgrp/chown/chomd
查看>>
待整理
查看>>
iOS 6
查看>>
Nginx入门篇-基础知识与linux下安装操作
查看>>
一次动态sql查询订单数据的设计
查看>>
C# 类(10) 抽象类.
查看>>
1.linux ping:unknown host www.***.***
查看>>
无向图求桥 UVA 796
查看>>
Nginx+Keepalived 实现双击热备及负载均衡
查看>>
五分钟搭建WordPress博客(二)
查看>>
Vue_(组件通讯)子组件向父组件传值
查看>>
jvm参数
查看>>
Something-Summary
查看>>
Spring学习笔记
查看>>