文档章节

spring 4.0 + mybatis + druid-1.0.11 .properties中 的 username password 加密

Z
 Z13
发布于 2017/01/18 16:38
字数 747
阅读 32
收藏 0

        在spring4.0 + mybatis + druid-1.0.11 中通过复写Spring 中的processProperties方法是实现不了.properties中的username和password 的加密的,因为好像druid会直接读取.properties中的东西,而不是直接在Spring管理的容器中获取。因此我们要通过其他的方法来实现加密。

       在网上查询资料的过程中发现原来druid自己提供加密的方法具体流程看https://github.com/alibaba/druid/wiki/%E4%BD%BF%E7%94%A8ConfigFilter  但是运用了druid的加密方法后发现mybatis跑不起来,由于时间紧急至于什么原因本人没有去深究。

        所以现在我打算复写spring中原来druid连接池的配置的 DruidDataSource的方法,然后想通过复写这个方法,在读取username和password的时候把密文解密,最好在交给druid去验证账号密码。

 

 

<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close"> 
	    <!-- 数据源驱动类可不写,Druid默认会自动根据URL识别DriverClass -->
	    <property name="driverClassName" value="${jdbc.driver}" />
	    
		<!-- 基本属性 url、user、password -->
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />
		
		<!-- 配置初始化大小、最小、最大 -->
		<property name="initialSize" value="${jdbc.pool.init}" />
		<property name="minIdle" value="${jdbc.pool.minIdle}" /> 
		<property name="maxActive" value="${jdbc.pool.maxActive}" />
		
		<!-- 配置获取连接等待超时的时间 -->
		<property name="maxWait" value="60000" />
		
		<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
		<property name="timeBetweenEvictionRunsMillis" value="60000" />
		
		<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
		<property name="minEvictableIdleTimeMillis" value="300000" />
		
		<property name="validationQuery" value="${jdbc.testSql}" />
		<property name="testWhileIdle" value="true" />
		<property name="testOnBorrow" value="false" />
		<property name="testOnReturn" value="false" />
		
		<!-- 打开PSCache,并且指定每个连接上PSCache的大小(Oracle使用)
		<property name="poolPreparedStatements" value="true" />
		<property name="maxPoolPreparedStatementPerConnectionSize" value="20" /> -->
		
		<!-- 配置监控统计拦截的filters -->
	    <property name="filters" value="stat" /> 
	</bean>

 

 

jdbc.username=56bd54bad4fa4f4f8ae8ddcf5faa1ac0//经过加密
jdbc.password=ffc24983a863f7fe77f884d721bca08f//经过加密

 

 

package com.common.security;

import com.alibaba.druid.pool.DruidDataSource;

@SuppressWarnings("serial")
public class MyDruidDataSource extends DruidDataSource {//需要继承DruidDataSource 实现类

@Override
public String getPassword()
{
return Cryptos.aesDecrypt(this.password);//aesDecrypt为对应的解密方法
}

@Override
public String getUsername()
{
return Cryptos.aesDecrypt(this.username);//aesDecrypt为对应的解密方法
}


}

<bean id="dataSource" class="com.common.security.MyDruidDataSource" init-method="init" destroy-method="close"> 
	    <!-- 数据源驱动类可不写,Druid默认会自动根据URL识别DriverClass -->
	    <property name="driverClassName" value="${jdbc.driver}" />
	    
		<!-- 基本属性 url、user、password -->
		<property name="url" value="${jdbc.url}" />
		<property name="username" value="${jdbc.username}" />
		<property name="password" value="${jdbc.password}" />
		
		<!-- 配置初始化大小、最小、最大 -->
		<property name="initialSize" value="${jdbc.pool.init}" />
		<property name="minIdle" value="${jdbc.pool.minIdle}" /> 
		<property name="maxActive" value="${jdbc.pool.maxActive}" />
		
		<!-- 配置获取连接等待超时的时间 -->
		<property name="maxWait" value="60000" />
		
		<!-- 配置间隔多久才进行一次检测,检测需要关闭的空闲连接,单位是毫秒 -->
		<property name="timeBetweenEvictionRunsMillis" value="60000" />
		
		<!-- 配置一个连接在池中最小生存的时间,单位是毫秒 -->
		<property name="minEvictableIdleTimeMillis" value="300000" />
		
		<property name="validationQuery" value="${jdbc.testSql}" />
		<property name="testWhileIdle" value="true" />
		<property name="testOnBorrow" value="false" />
		<property name="testOnReturn" value="false" />
		
		<!-- 打开PSCache,并且指定每个连接上PSCache的大小(Oracle使用)
		<property name="poolPreparedStatements" value="true" />
		<property name="maxPoolPreparedStatementPerConnectionSize" value="20" /> -->
		
		<!-- 配置监控统计拦截的filters -->
	    <property name="filters" value="stat" /> 
	    
	</bean>

 

 

 

本文转载自:http://peak1992.iteye.com/blog/2283709

共有 人打赏支持
Z

Z13

粉丝 0
博文 8
码字总数 0
作品 0
广州
程序员
私信 提问
Spring Boot 集成 Mybatis 实现双数据源

这里用到了Spring Boot + Mybatis + DynamicDataSource配置动态双数据源,可以动态切换数据源实现数据库的读写分离。 添加依赖 加入Mybatis启动器,这里添加了Druid连接池、Oracle数据库驱动...

Java技术栈
2018/06/08
0
0
spring+springMVC+mybatis的框架项目基础环境搭建

上一个项目在后台用到spring+springMVC+mybatis的框架,先新项目初步需求也已经下来,不出意外的话,应该也是用这个框架组合。 虽然在之前activiti相关的学习中所用到的框架也是这个,但是当...

涂宗勋
2016/04/14
543
0
springMVC4+mybatis+Druid+Maven

整个框架结构 pom.xml web.xml spring-mvc.xml 通过实践这个路径不行,扫描找不到要注入的类,只能把mapping文件放在resources下 spring-mybatis.xml mybatis-config.xml jdbc.properties ma...

lcyanxi
2016/11/18
82
0
阿里巴巴Druid数据源的配置与使用

Druid是阿里巴巴开源平台上的一个项目,整个项目由数据库连接池、插件框架和SQL解析器组成。该项目主要是为了扩展JDBC的一些限制,可以让程序员实现一些特殊的需求,比如向密钥服务请求凭证、...

wangjianme
2016/05/21
659
1
苞米豆多数据源启动器 2.0.1 发布,Bug 修复版本

苞米豆多数据源启动器 2.0.1 发布了。强烈建议升级!更新内容: 修复一个方法缓存的bug,会引起同名方法的注解失效。 底层代码的重命名和部分格式的调整。 源码地址: https://gitee.com/ba...

小锅盖
2018/08/09
501
4

没有更多内容

加载失败,请刷新页面

加载更多

rabbitmq

灰暗
34分钟前
1
0
Flink

flink HA部署 flink搭建,采用分布式部署方式,分别为A,B,C三个节点。其中A为master;A,B,C为worker。 本文使用的用户是hadoop用户(自己新建) 先决条件 Java 1.8.x or higher scala 自己使用...

-九天-
今天
2
0
数据中台和传统数仓的区别

中台系统把业务层同性的算法能力,服务能力,业务能力高度集成,有效组织 ,动态规划。更好的帮助上层业务。 今天就让我们看看关于数据中台的问答吧。 1 Q : 什么是数据中台? A : 数据中台是...

hblt-j
今天
4
0
Java在什么时候会出现内存泄漏

在Java中,内存泄漏就是存在一些被分配的对象,这些对象有下面两个特点,首先,这些对象是可达的,即在有向图中,存在通路可以与其相连;其次,这些对象是无用的,即程序以后不会再使用这些对...

群星纪元
今天
2
0
android 打开摄像头

private SurfaceHolder mHolder; private SurfaceView mSurfaceView; private Camera mCamera; mSurfaceView = (SurfaceView) this.findViewById(R.id.camsurfaceView1); mHolder = mSurface......

jingshishengxu
今天
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部