AOP(Aspect Oriented Programming):面向切面编程。
面向切面编程(也叫面向方面编程),是目前软件开发中的一个热点,也是Spring框架中的一个重要内容。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。
主要用途:日志记录,性能统计,安全控制,权限管理,事务处理,异常处理,资源池管理。
各个通知:
A 前置通知(Before advice) :在某连接点(JoinPoint)之前执行的通知,但这个通知不能阻止连接点前的执行。xml中在<aop:aspect>里面使用<aop:before>元素进行声明;例如,TestAspect中的doBefore方法。注解中使用@Before声明;例如,TestAnnotationAspect中的doBefore方法。
B 后通知(After advice) :当某连接点退出的时候执行的通知(不论是正常返回还是异常退出)。xml中在<aop:aspect>里面使用<aop:after>元素进行声明。例如,TestAspect中的doAfter方法,所以AOPTest中调用BServiceImpl.barB抛出异常时,doAfter方法仍然执行。注解中使用@After声明。
C 返回后通知(After return advice) :在某连接点正常完成后执行的通知,不包括抛出异常的情况。xml中在<aop:aspect>里面使用<after-returning>元素进行声明。注解中使用@AfterReturning声明;
D 环绕通知(Around advice) :包围一个连接点的通知,类似Web中Servlet规范中的Filter的doFilter方法。可以在方法的调用前后完成自定义的行为,也可以选择不执行。xml中在<aop:aspect>里面使用<aop:around>元素进行声明。例如,TestAspect中的doAround方法。注解中使用@Around声明。
E 抛出异常后通知(After throwing advice) : 在方法抛出异常退出时执行的通知。xml中在<aop:aspect>里面使用<aop:after-throwing>元素进行声明。例如,TestAspect中的doThrowing方法。注解中使用@AfterThrowing声明。
通知执行顺序:前置通知→环绕通知连接点之前→连接点执行→环绕通知连接点之后→返回通知→后通知→(如果发生异常)异常通知→后通知
1、applicationContext.xml文件配置,以下带下划线的几处地方
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx" xmlns:jdbc="http://www.springframework.org/schema/jdbc" <xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd http://www.springframework.org/schema/jdbc http://www.springframework.org/schema/jdbc/spring-jdbc-3.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd"> <aop:aspectj-autoproxy /> ...... ...... </beans>
2、创建AOP类
package cn.com.abel.springProject.aop; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.ProceedingJoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.AfterReturning; import org.aspectj.lang.annotation.AfterThrowing; import org.aspectj.lang.annotation.Around; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.stereotype.Component; @Component @Aspect public class TestAop { //环绕通知 @Around("execution(* cn.com.abel.springProject.service.TestService.sayHello(..))") public void aroundExecute(ProceedingJoinPoint point) throws Throwable{ System.out.println("================Around start"); //参数:point.getArgs()[0]下标表示方法的第几个参数,从0开始。下同 point.proceed(); System.out.println("================Around end"); } //前置通知 @Before("execution(* cn.com.abel.springProject.service.TestService.sayHello(..))") public void beforeExecute(JoinPoint point) throws Throwable{ System.out.println("================Before"); //参数:point.getArgs()[0] } //后置通知 @AfterReturning("execution(* cn.com.abel.springProject.service.TestService.sayHello(..))") public void afterReturningExecute(JoinPoint point) throws Throwable{ System.out.println("================AfterReturning"); } //抛出异常后通知 @AfterThrowing("execution(* cn.com.abel.springProject.service.TestService.sayHello(..))") public void afterThrowingExecute(JoinPoint point) throws Throwable{ System.out.println("================AfterThrowing"); } //最终通知 @After("execution(* cn.com.abel.springProject.service.TestService.sayHello(..))") public void afterExecute(JoinPoint point) throws Throwable{ System.out.println("================After"); } }
package cn.com.abel.springProject.service; import org.springframework.stereotype.Service; @Service public class TestService { public String sayHello(Integer age, String name){ System.out.println("================hello word"); } }
TestService.sayHello方法,无异常情况下输出结果:
================Around start
================Before
================hello word
================AfterReturning
================Around end
================After
出现异常时的结果:
================Around start
================Before
================hello word
================AfterThrowing
================After
原文地址:http://blog.csdn.net/rongku/article/details/42529133