Spring AOP 中的控制流切入点

本文深入探讨了Spring AOP中的控制流切入点,展示了如何匹配类中的特定方法调用,并通过示例代码解释了其工作原理。实验结果显示,控制流切入点能够精准地拦截目标方法,实现方法执行前的拦截。
摘要由CSDN通过智能技术生成

1 控制流切入点

          匹配一个类的某一个方法或该方法下的所有方法调用。

。实现代码如下:

package cuigh.spring.aop.step02;

import org.aopalliance.aop.Advice;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.aop.Advisor;
import org.springframework.aop.Pointcut;
import org.springframework.aop.framework.ProxyFactory;
import org.springframework.aop.support.ControlFlowPointcut;
import org.springframework.aop.support.DefaultPointcutAdvisor;
/**
 * 功能:演示控制流切入点使用
 */
public class ControlFlowPointcutExample {
	
	static Log log = LogFactory.getLog(ControlFlowPointcutExample.class);

	public static void main(String[] args) {

		//创建目标
		TestControlFlowPointcut target = new TestControlFlowPointcut();
		//创建 通知 
		Advice advice = new MyBeforeAdvice();
		//创建切入点 MyDynamicPointcut 方法 testNotAdvice() 被拦截
		Pointcut pointcut = new ControlFlowPointcut(TestControlFlowPointcut.class,"testNotAdvice");
		//创建通知者
		Advisor  advisor = new DefaultPointcutAdvisor(pointcut,advice);
		
		//创建代理
		ProxyFactory pf = new ProxyFactory();
		pf.setTarget(target);
		pf.addAdvisor(advisor);
		TestControlFlowPointcut proxy = (TestControlFlowPointcut)pf.getProxy();
		
		log.info("-----下面未被拦截------");
		target.test(proxy);
		log.info("-----下面被拦截------");
		target.testNotAdvice(proxy);

	}
}
package cuigh.spring.aop.step02;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
/*
 * 功能:控制流切入点示例类
 * */
public class TestControlFlowPointcut {
	static Log log = LogFactory.getLog(TestControlFlowPointcut.class);

	public void test1(){
		log.info(this.getClass().getName()+".test1()");
	}
	
	public void test2(){
		log.info(this.getClass().getName()+".test2()");
	}
	
	public void test(TestControlFlowPointcut bean){
		bean.test1();
		bean.test2();
	}
	//对此方法进行拦截
	public void testNotAdvice(TestControlFlowPointcut bean){
		bean.test1();
		bean.test2();
	}
}

package cuigh.spring.aop.step02;

import java.lang.reflect.Method;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.aop.MethodBeforeAdvice;

public class MyBeforeAdvice implements MethodBeforeAdvice {

	static Log log = LogFactory.getLog(MyBeforeAdvice.class);
	@Override
	public void before(Method method, Object[] args, Object target)
			throws Throwable {
		log.info("方法执行前拦截,被拦截方法="+method.getName());
	}
}

程序输出:

2013-07-20 19:35:44,343 [ControlFlowPointcutExample.java  39] INFO  - -----下面未被拦截------

2013-07-20 19:35:44,359 [TestControlFlowPointcut.java  10] INFO  - cuigh.spring.aop.step02.TestControlFlowPointcut.test1()

2013-07-20 19:35:44,359 [TestControlFlowPointcut.java  14] INFO  - cuigh.spring.aop.step02.TestControlFlowPointcut.test2()

2013-07-20 19:35:44,359 [ControlFlowPointcutExample.java  41] INFO  - -----下面被拦截------

2013-07-20 19:35:44,359 [MyBeforeAdvice.java  15] INFO  - 方法执行前拦截,被拦截方法=test1

2013-07-20 19:35:44,359 [TestControlFlowPointcut.java  10] INFO  - cuigh.spring.aop.step02.TestControlFlowPointcut.test1()

2013-07-20 19:35:44,359 [MyBeforeAdvice.java  15] INFO  - 方法执行前拦截,被拦截方法=test2

2013-07-20 19:35:44,359 [TestControlFlowPointcut.java  14] INFO  - cuigh.spring.aop.step02.TestControlFlowPointcut.test2()



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值