今天重新看了 动态代理模式,又看了一遍Spring AOP,把我的项目慢慢的添加Spring,把我了解的AOP和大家分享一下。
下面的例子参考了别人的代码
添加Spring3.0 需要的包
定义一个接口 HelloInterface
package rw.hello; public interface HelloInterface { void BeforeHello(); void ExecuteHello(); void AfterHello(); }
package rw.hello; public class Hello implements HelloInterface{ public void BeforeHello() { // TODO Auto-generated method stub System.out.println("----------------Hello 方法执行之前"); } public void ExecuteHello() { // TODO Auto-generated method stub System.out.println("----------------Hello 方法执行中......"); } public void AfterHello() { // TODO Auto-generated method stub System.out.println("----------------Hello 方法执行之后"); } }
BeforeHello(),ExecuteHello(),AfterHello()这三个方法执行之前做其它事情,比如权限问题,记录日志之类.....反正我今天是添加的用户权限问题 同样有3个类,风别是BeforeHello(),ExecuteHello(),AfterHello()这三个方法调用之前要调用的 下面只测试一下After.java 和 Before.java After.java package rw.method; import org.aspectj.lang.JoinPoint; public class After { public void invoke(JoinPoint joinpoint){ System.out.println("After 类"+joinpoint.getSignature().getName()); } } Before.java package rw.method; import org.aspectj.lang.JoinPoint; public class Before { public void invoke(JoinPoint joinpoint){ System.out.println("Before 类"+joinpoint.getSignature().getName()); } }最注意的还是 applicationContext.xml的配置
<?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:aop="http://www.springframework.org/schema/aop" xmlns:p="http://www.springframework.org/schema/p" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/aop http://www.springsource.org/schema/aop/spring-aop-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"> <bean id="hello" class="rw.hello.Hello"/> <bean id="after" class="rw.method.After"/> <bean id="before" class="rw.method.Before"/> <bean id="execute" class="rw.method.Execute"/> <aop:config> <aop:pointcut expression="execution(* rw.hello.HelloInterface.BeforeHello(..))" id="beforepointcut"/> <aop:aspect id="beforeaspect" ref="before"> <aop:before method="invoke" pointcut-ref="beforepointcut"/> </aop:aspect> </aop:config> <aop:config> <aop:pointcut expression="execution(* rw.hello.HelloInterface.AfterHello(..))" id="afterpointcut"/> <aop:aspect id="afteraspact" ref="after"> <aop:after method="invoke" pointcut-ref="afterpointcut"/> </aop:aspect> </aop:config> </beans>排版不是很好
1,在Hello的BeforeHello()方法执行之前 会调用Before类中的invoke(JoinPoint joinpoint)方法
2,在Hello的AfterHello()方法执行之后 会调用After类中的invoke(JoinPoint joinpoint)方法
测试类
package rw.test; import org.junit.Before; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import rw.hello.HelloInterface; public class AllTest { private ApplicationContext context; @Before public void setUp() throws Exception { context=new ClassPathXmlApplicationContext("applicationContext.xml"); } @Test public void TestHelloInterface(){ HelloInterface hello=(HelloInterface) context.getBean("hello"); hello.BeforeHello(); hello.AfterHello(); } }
Hello 类中的 void ExecuteHello()方法在applicationContext.xml中没有加以任何配置
正常输出