MYBATIS Intercepter 数据库加密

项目中遇到要对数据库加密,简单的方法是在构建实体类时调用加密算法加密后,调用insert插入数据库,但这样做比较繁琐,mybatis 的拦截器可以解决这个问题:代码如下:
@Intercepts({
	@Signature(type=Executor.class,method="update",args={MappedStatement.class,Object.class}),
	@Signature(type=Executor.class,method="query",args={MappedStatement.class,Object.class,RowBounds.class,ResultHandler.class})
	})
public class DBInterceptor implements Interceptor{
	
	 private final Logger logger = LoggerFactory.getLogger(DBInterceptor.class);

	@Override
	public Object intercept(Invocation invocation) throws Throwable {
		MappedStatement statement = (MappedStatement) invocation.getArgs()[0];
		String methodName = invocation.getMethod().getName();
		Object parameter = invocation.getArgs()[1];
		BoundSql sql = statement.getBoundSql(parameter);
		logger.info("sql is {}",sql.getSql());
		if(parameter instanceof SystemUser){
			SystemUser user = (SystemUser)parameter;
			if(methodName.equals("query")){
				
			}else if(methodName.equals("update")){
				user.setName(DBSecurityUtil.getInstance().encrypt(user.getName()));
				user.setPassword(Digests.md5(user.getPassword().getBytes()));
			}
		}
		Object returnValue = invocation.proceed();
		if(returnValue instanceof ArrayList<?>){
			List<?> list = (ArrayList<?>)returnValue;
			for(Object val:list){
				if(val instanceof SystemUser){
					SystemUser user = (SystemUser)val;
					logger.debug("user name is {}",user.getName());
					user.setName(DBSecurityUtil.getInstance().decrypt(user.getName()));
					logger.debug("user name is {}",user.getName());
				}
			}
		}
		return returnValue;
	}

	@Override
	public Object plugin(Object target) {
		return Plugin.wrap(target, this);
	}

	@Override
	public void setProperties(Properties properties) {
		// TODO Auto-generated method stub
		
	}
	
	

}

spring 配置如下:

  <!-- MyBatis配置 -->
	<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
		<property name="dataSource" ref="dataSource" />
		<!-- 自动扫描entity目录, 省掉Configuration.xml里的手工配置 -->
		<property name="typeAliasesPackage" value="com.xxxx.entity" />
		<!-- 显式指定Mapper文件位置 -->
		<property name="mapperLocations" value="classpath:/com/xxx/repository/mybatis/mapper/*Mapper.xml" />
		<!-- 配置Mybatis的插件plugin-->
    <property name="plugins">
        <array>
            <bean class="com.xxxx.utils.security.DBInterceptor">
                <property name="properties">
                    <value>
                        property-key=property-value
                    </value>
                </property>
            </bean>
        </array>
    </property>
	</bean>










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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值