mybatis-数据库配置文件密码加密

一般情况下开发都是在数据库配置文件中使用的明文密码,但在一些特殊情况下也会需要对其进行加密,否则会造成数据泄露。
最近公司刚好有这个需求,趁此机会将我的实现方法写下来以供大家参考。

原理:直接重写DataSource类的setPassword方法

创建一个DataSource类继承spring-mybatis.xml文件中配置的DataSource类,然后重写它的setUsername和setPassword方法。
如下:
在这里插入图片描述
我这里原本的配置是“org.springframework.jdbc.datasource.DriverManagerDataSource”,我自己的DataSource类就继承它

import java.io.UnsupportedEncodingException;
import java.util.Base64;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.jdbc.datasource.DriverManagerDataSource;
 
public class MyDataSource extends DriverManagerDataSource {

	private final static Logger logger = LoggerFactory.getLogger(MyDataSource.class);
	
	public MyDataSource() {
		super();
	}
	
	@Override
	public void setPassword(String password){
		try{
			super.setPassword(decode(password));
		}catch(Exception e){
			logger.error(e.getMessage());
		}
	}
	
	@Override
	public void setUsername(String username) {
		try{
			super.setUsername(decode(username));
		}catch(Exception e){
			logger.error(e.getMessage());
		}
	}
	
	//加密
	public static String encodeToString(String password){
		//编码
	    String str=null;
	    try {
	        str = Base64.getEncoder().encodeToString(password.getBytes("utf-8"));
	        System.out.println("编码结果为:"+str);
	    } catch (UnsupportedEncodingException e) {
	    	logger.error(e.getMessage());
	    }
	    
		return str;
	}

	//解密
	public static String decode(String password){
		//解码
		String str=null;
	    byte[] str1=Base64.getDecoder().decode(password);
	    try {
	    	str = new String(str1,"utf-8");
	        System.out.println("解码结果为:"+str);
	    } catch (UnsupportedEncodingException e) {
	    	logger.error(e.getMessage());
	    }
		return str;
	}
	
//	public static void main(String[] args) {
//		encodeToString("admin");
//		decode(encodeToString("admin"));
//	}
}

然后再将配置文件中原本的“org.springframework.jdbc.datasource.DriverManagerDataSource”改成自己的类
在这里插入图片描述
最后将jdbc.properties文件中的用户名和密码改为加密后的文本就可以了。

以上就是mybatis-数据库配置文件密码加密的全部内容,如果有不同见解欢迎在评论区交流。
参考文章:https://blog.csdn.net/qq_24241631/article/details/80294144

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值