初尝Spring AOP --实现多数据源切换

AOP配置 参考
http://blog.csdn.net/voyage_mh1987/article/details/5821238

客户管理系统中,需要从不同的系统中获取客户的信息。有的系统用的是Oracle,有的用SqlServer。

之前在网上看到过ibatis下修改配置文件,实现多数据源。

项目中最终决定使用的是通过Spring AOP机制,实现在代码中不同的位置使用不同的数据源。

切面类 ,用于切换数据源:

package com.paic.yxd.cis.cust.util;

import java.lang.reflect.Method;

import javax.sql.DataSource;


import org.aspectj.lang.JoinPoint;
import org.springframework.orm.ibatis.SqlMapClientTemplate;
@SuppressWarnings("unchecked")
public class ProxyDataSource{
    public void setCISDataSource(JoinPoint joinPoint){
        String dataSource=CustConstant.getString(CustConstant.DATASOURCE_CIS);
        commonUtilSettings(joinPoint,dataSource);
    }
    public void setAntifrauderyDataSource(JoinPoint joinPoint){
        String dataSource=CustConstant.getString(CustConstant.DATASOURCE_ANTIFRAUDERY);
        commonUtilSettings(joinPoint,dataSource);
    }   
    private void commonUtilSettings(JoinPoint joinPoint,String dataSourceName){
        Object obj=joinPoint.getTarget();
        Class<?> typeClass=obj.getClass();
        String methodName=CustConstant.getString("getSqlMapClientTemplate");
        SqlMapClientTemplate sqlMapClientTemplate=getObjectByMethod(obj,typeClass,methodName,SqlMapClientTemplate.class);
        setDataSource(sqlMapClientTemplate,dataSourceName);
    }
    private <T> T getObjectByMethod(Object object,Class<?> objectType,String methodName,Class<? extends T> returnType){
        T result=null;
        try {
            Method method=objectType.getDeclaredMethod(methodName, new Class<?>[0]);
            result=(T)method.invoke(object, new Object[0]);
        } catch (Exception e){
            e.printStackTrace();
        }
        return result;
    }

    private void setDataSource(SqlMapClientTemplate sqlMapClientTemplate,String dataSourceName){
        DataSource dataSource=ApplicationContextUtil.getApplicationContext().getBean(dataSourceName, DataSource.class);
        sqlMapClientTemplate.setDataSource(dataSource);
    }

}

配置AOP,配置切点的位置,使上述方法在此切点之前执行,导入主配置文件

<?xml version="1.0" encoding="utf-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xmlns:context="http://www.springframework.org/schema/context"
    xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx"
    xmlns:util="http://www.springframework.org/schema/util"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
         http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
         http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
         http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd
         http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.0.xsd">
    <description>
        切面AOP 动态切换数据源(客户管理系统数据源和反欺诈平台数据源)
    </description>  
    <bean id="proxyDataSource" class="com.paic.yxd.cis.cust.util.ProxyDataSource"></bean>

    <aop:config>
        <aop:aspect  ref="proxyDataSource">
            <aop:pointcut id="cisPointer" expression="execution(* com.paic.yxd.cis.cust.dao.impl.Cust*.*(..))" />
            <aop:pointcut id="antifrauderyPointer" expression="execution(* com.paic.yxd.cis.cust.dao.impl.Tag*.*(..))" />
            <aop:before method="setCISDataSource" pointcut-ref="cisPointer"/>
            <aop:before method="setAntifrauderyDataSource" pointcut-ref="antifrauderyPointer"/>
        </aop:aspect>
    </aop:config>
</beans>

导入主配置文件

<IMPORT resource="biz-context-aop.xml"/>
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值