1启用Spring的AspectJ注解支持
问题:
Spring支持在其AOP框架中使用AspectJ注解编写的POJO aspect。但是,你必须首先启用Spring中的AspectJ注解支持。
解决方案:
你只需要在Bean配置文件中定义一个空的XML元素<aop:aspectj-autoproxy/>,就可以启用Spring IoC容器中的AspectJ注解支持。
然后,Spring将自动为匹配你的AspectJ aspect的所有Bean创建代理。
对于接口不可用或者没有用于应用设计中的情况,可以依靠CGLIB创建代理。为了启用CGLIB,必须在<aop:aspectj-autoproxy>中设置proxy-targetclass=true属性。
2用AspectJ注解声明aspect
问题:
从第5版与AspectWerkz合并起,AspectJ支持将其aspect编写为带有一租AspectJ注解的POJO。
Spring AOP框架也支持这种aspect,但是这些aspect必须在Spring IoC容器中注册方可生效。
解决方案:
要在Spring中注册AspectJ aspect,只需要将他们声明为IoC容器中的Bean实例就行了。
在Spring IoC容器中启用AspectJ,容器将自动为匹配AspectJ aspect的Bean创建代理。
用AspectJ注解编写的aspect只是一个带有@Aspect注解的java类。通知(Advice)是带有一个通知注解的简单Java方法。
AspectJ注解5中通知注解:@Before、@After、@AfterReturning、@AfterThrowing和@Around。
工作原理:
前置通知:
@Before
方式一:简单方式,只是添加注解
@Aspect
public class LoggingBeforeAspect {
private Log log = LogFactory.getLog(LoggingBeforeAspect.class);
@Before("execution(* *..*.delete(..))")
public void logBefore(){
log.debug("The method add() begins");
}
}
然后把这个class注册进IoC就可以,可以以匿名的方式注册
<aop:aspectj-autoproxy />
<bean id="userDao" class="com.partner4java.aspectj.demo1.UserDaoImpl"/>
<bean class="com.partner4java.aspectj.demo1.LoggingBeforeAspect"/>
方式二:我们还可以拿到连接点
@Aspect
public class LoggingBeforeAspect1 {
private Log log = LogFactory.getLog(LoggingBeforeAspect1.class);
@Before("execution(* *..*.delete(..))")
public void logBefore(JoinPoint joinPoint){
log.debug("The method "+ joinPoint.getSignature().getName() +" add() begins");
}
}
最终通知:
最终通知(after advice)在连接点结束之后执行,不管返回结果还是抛出异常。
@Aspect
public class LoggingAfterAspect {
private Log log = LogFactory.getLog(LoggingAfterAspect.class);
@After("execution(* *..*.delete(..))")
public void logBefore(JoinPoint joinPoint) {
log.debug("The method " + join