您的位置:首页 > 编程语言 > Java开发

Spring AOP 代理

2011-03-28 17:31 204 查看
以前,在看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 --- 代理类之后执行

//完成测试
阅读更多
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: