AOP以及其在Spring中的应用(二)

类别:Java 点击:0 评论:0 推荐:

Spring中AOP的实现就是通过动态代理来实现的。动态代理的实现在上篇blog中已经涉及。Spring中目前最为实用的AOP应用,非用其实现的事务管理机制莫属。也正是这一点,使得Spring AOP大方异彩。

那么我们继续围绕上节的例子来探讨一下Spring中AOP机制的应用与开发。

首先,看看AOP中几个基本的概念对应在AOP中的实现:

Ø         切点(PointCut)

一系列连接点的集合,它指明处理方式(Advice)将在何时被触发。

对于我们开发而言,“何时触发”的条件大多是面向Bean的方法进行制定。像Spring的配置化事务管理时针对方法名称可进行PointCut设置,从而指定对所有以声明字符开头的方法进行基于AOP的事务管理。那么同样,对于我们自己实现的AOP组件而言,我们也可以以方法名作为触发判定条件。

我们可以通过在XML配置文件中配置以下节点,为我们的组件设定触发条件。

<bean id="myPointcutAdvisor"

class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">

<property name="advice">

<ref local="MyInterceptor" />

</property>

<property name="patterns">

<list>

<value>.*save.*</value>

<value>.*do.*</value>

</list>

</property>

</bean>

上面我们针对MyInterceptor设定了一个基于方法名的触发条件,也就是说,当目标类的指定方法运行时,MyInterceptor即被触发。

Ø         处理方式(Advice)

也就是说要实现一个Interceptor,以供在连接点时触发。Spring中采用了AOP联盟(AOP Alliance)的通用AOP接口(接口定义位aopalliance.jar)。这里我们采用aopalliance.jar中定义的MethodInterceptor作为我们的Advice实现接口。那么我们上节例子中的处理方式应实现为如下Interceptor:

package test.aop.spring;

import java.util.logging.Logger;

import org.aopalliance.intercept.MethodInterceptor;

import org.aopalliance.intercept.MethodInvocation;

 

/**

 * @author xkf

 **/

public class LockInterceptor implements MethodInterceptor {

    private Logger logger = Logger.getLogger(this.getClass().getName());

    public Object invoke(MethodInvocation invocation) throws Throwable {

        // TODO Auto-generated method stub

        lock();

        Object ret= invocation.proceed();

        unlock();

        return ret;

    }

    private void lock(){

        logger.info("lock domain object...");

    }

    private void unlock(){

        logger.info("unlock domain object...");

    }

}

实现后,对应的Interceptor实现类在配置文件中的体现如下:

<bean id="MyInterceptor" class="test.aop.spring.LockInterceptor"/>

最后,我们还需要定义一个Spring AOP ProxyFactory用于加载执行AOP组件,并且需要将Advice通过IOC的方式注入到接口以及实现类。

对应的配置文件应如下配置从而实现这些内容:

<bean id="myAOPProxy" class="org.springframework.aop.framework.ProxyFactoryBean">

    <property name="proxyInterfaces">

      <value>test.aop.spring.DomainObjDAO</value>

    </property>

    <property name="target">

      <ref local="impl" />

    </property>

    <property name="interceptorNames">

      <value>myPointcutAdvisor</value>

    </property>

  </bean>

  <bean id="impl" class="test.aop.spring.DomainObjDAOImpl"/>

万事大吉!写一个TestCase来看一下运行结果:

package test.aop.spring;

 

import junit.framework.TestCase;

import org.springframework.context.ApplicationContext;

import org.springframework.context.support.FileSystemXmlApplicationContext;

 

/**

 * @author xkf

*/

public class SpringTestCase extends TestCase {

    DomainObjDAO test=null;

 

    protected void setUp() throws Exception {

        super.setUp();

        ApplicationContext ctx=new FileSystemXmlApplicationContext("test/Bean.xml");

        test = (DomainObjDAO) ctx.getBean("myAOPProxy");

    }

 

    protected void tearDown() throws Exception {

        super.tearDown();

    }

    public void testSave(){

        test.save();

    }

}

运行结果如下:

信息: Creating shared instance of singleton bean 'MyInterceptor'

2004-12-7 23:50:11 test.aop.spring.LockInterceptor lock

信息: lock domain object...

saving domain object......

2004-12-7 23:50:11 test.aop.spring.LockInterceptor unlock

信息: unlock domain object...

    OK!至此,我们已经探讨了AOP动态代理的实现以及其在Spring中的应用,接下来的Blog中我将会关注Spring中事务以及持久化的实现。

本文地址:http://com.8s8s.com/it/it12732.htm