Spring AOP 代理

以前,在看Spring AOP代理时,老是不明白书上说的Point Cut(切入点),Join Point(连接点), Advice(通知), Advisor(配置器),这些词倒底是什么意思,最近,看了好多遍,反复的测试,终于明白一些了.

Point Cut (切入点) = (Join Point 连接点的集合)
Advice (通知) 是要执行代理的代码
Advisor = Point Cut + Advice

其实一个类TestDaoImpl,如果想实现代理,首先要实现一个接口TestDao,然后再要有一个代理类,如日志代理 (MyLoggerProxy), MyLoggerProxy这个类要实现 Advice(通知)其中的一个方法,Advice有五种类型 Interception, Around,Before, After Running, Throw , Introduction. 然后再在bean配置文件中,配置一下。具体代码如下:

TestDaoImpl.java   (以下的连接点1 + 连接点2 + 连接点3 = Point Cut )
public class TestDaoImpl implements TestDao{
      public void doFristTask()    //这里就是一个 Join Point (连接点1)
      {
            // do task 1
     }

     public void doSecondTask() //这里就又是一个 Join Point (连接点2)
    {
        // do task 2
    }
     public void doThreeTask() //这里就又是一个 Join Point (连接点3)
    {
     // do task 3
    }
}

MyLoggerProxy.java

public class MyLoggerProxy implements MethodInterceptor {

private Logger logger = Logger.getLogger(this.getClass());
//通知Advice
public Object invoke(MethodInvocation in) throws Throwable {
   logger.log(Level.INFO, "代理类之前执行...");
   Object result = in.proceed();         //这里执行了 target 类
logger.log(Level.INFO, "代理类之后执行...");
   return result;
}

}

第一种在application.xml文件中配置的方法:(这里是针对所有的方法)

<bean id="testDao" class="com.gc.dao.TestDao"/>

<bean id="myLoggerProxy" class="com.gc.dao.MyLoggerProxy"/>

<bean id="logProxy"
   class="org.springframework.aop.framework.ProxyFactoryBean">
   <property name="proxyInterfaces">//代理接口
    <value>com.gc.dao.TestDao</value>
   </property>
   <property name="target">//要代理的类,实现了TestDao接口
    <ref bean="testDao" />
   </property>
   <property name="interceptorNames">//代理类
    <list>
     <value>myLoggerProxy</value>
       </list>
   </property>
</bean>

第二种在application.xml文件中配置的方法:(这里是针对特定的方法)

<bean id="testDao" class="com.gc.dao.TestDao"/>

<bean id="myLoggerProxy" class="com.gc.dao.MyLoggerProxy"/>

<!--配置器-->
<bean id="logAdvisor"
   class="org.springframework.aop.support.RegexpMethodPointcutAdvisor">
   <property name="advice">
    <ref local="myLoggerProxy" />
   </property>
   <property name="patterns">
    <value>.*do.*</value>
   </property>
</bean>

<!--代理类-->

<bean id="logProxy"
   class="org.springframework.aop.framework.ProxyFactoryBean">
   <property name="proxyInterfaces">
    <value>com.gc.dao.TestDaoImpl</value> <!--如果是CGLIB代理,设置proxyTargetClass为true-->
   </property>
   <property name="target">
    <ref bean="testDao" />
   </property>
   <property name="interceptorNames">
    <list>
     <value>logAdvisor</value>
    </list>
   </property>
</bean>

测试类:

   ApplicationContext actx = new FileSystemXmlApplicationContext("src/applicationContext.xml");
   TestDao test = (TestDao) actx.getBean("logProxy");
   test.doFristTask();//这里doFristTask是testDaoImpl里的一个方法

   //结果:
            Info --- 代理类之前执行.
             // Do Task 1
            Info --- 代理类之后执行

//完成测试

你可能感兴趣的:(DAO,spring,AOP,xml,bean)