设为首页 加入收藏

TOP

Spring AOP的注解实例(一)
2015-11-12 23:05:55 来源: 作者: 【 】 浏览:22
Tags:Spring AOP 注解 实例

实现Spring AOP需要导入四个包,这里用maven引入jar包,颜色标注处的jar包,上一篇已经介绍了


? ? ?
? ? ? ? ? ? cglib
? ? ? ? ? ? cglib-nodep
? ? ? ? ? ? 2.1_3
? ? ? ?

? ? ? ?
? ? ? ? ? ? aopalliance
? ? ? ? ? ? aopalliance
? ? ? ? ? ? 1.0
? ? ? ?

? ? ? ?
? ? ? ? ? ? org.aspectj
? ? ? ? ? ? aspectjrt
? ? ? ? ? ? 1.6.11
? ? ? ?

? ? ? ?
? ? ? ? ? ? org.aspectj
? ? ? ? ? ? aspectjweaver
? ? ? ? ? ? 1.6.11
? ? ? ?


在applicationContext-mvc.xml(或spring-mvc.xml)中加入下面两句话,意思是:声明XML Schema 实例


? ? ? xmlns:aop="http://www.springframework.org/schema/aop"


? ? ? xsi:schemaLocation="http://www.springframework.org/schema/aop


? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? http://www.springframework.org/schema/aop/spring-aop-3.2.xsd


然后开启@AspectJ注解


在applicationContext-mvc.xml配置如下:


? ?
? ?
? ?
? ?
? ?
? ?


其中要注意的是这两个不能少,在applicationContext-mvc.xml文件中开始时指定


? ?
? ?
? ?


下面开始定义切面,先了解下其基本知识要点


? ? ? * 连接点(Joinpoint) :程序执行过程中的某一行为(方法),例如,UserService.get()的调用或者UserService.delete()抛出异常等行为。
? ? ? * 通知(Advice) :“切面”对于某个“连接点”所产生的动作,例如,TestAspect中对com.spring.service包下所有类的方法进行日志记录的动作就是一个Advice。其中,一个“切面”可以包含多个“Advice”,例如ServiceAspect。
? ? ? * 切入点(Pointcut) :匹配连接点的断言,在AOP中通知和一个切入点表达式关联。例如,TestAspect中的所有通知所关注的连接点,都由切入点表达式execution(* com.spring.service.impl..*.*(..))来决定。
? ? ? * 目标对象(Target Object) :被一个或者多个切面所通知的对象。例如,AServcieImpl和BServiceImpl,在实际运行时,Spring AOP采用代理实现,实际AOP操作的是TargetObject的代理对象。
? ? ? * AOP代理(AOP Proxy) :在Spring AOP中有两种代理方式,JDK动态代理和CGLIB代理。默认情况下,TargetObject实现了接口时,则采用JDK动态代理,例如,AServiceImpl;反之,采用CGLIB代理,例如,BServiceImpl。强制使用CGLIB代理需要将 的 proxy-target-class属性设为true 。


? ? 通知(Advice)类型


? ? ? *前置通知(Before advice) :在某连接点(JoinPoint)之前执行的通知,但这个通知不能阻止连接点前的执行。


? ? ? *后通知(After advice) :当某连接点退出的时候执行的通知(不论是正常返回还是异常退出)。


? ? ? *返回后通知(After return advice) :在某连接点正常完成后执行的通知,不包括抛出异常的情况。


? ? ? *环绕通知(Around advice) :包围一个连接点的通知,类似Web中Servlet规范中的Filter的doFilter方法。可以在方法的调用前后完成自定义的行为,也可以选择不执行。


? ? ? *抛出异常后通知(After throwing advice) : 在方法抛出异常退出时执行的通知。


定义一个接口,并编写实现类:


? ? public interface UserService {
? ? ? ? public void addUser(String userName, String password);
? ? }


? ? @Service("userService")
? ? public class UserServiceImpl implements UserService {


? ? ? @Override
? ? ? ? public void addUser(String userName, String password) {? ? ?
? ? ? ? ? ? System.out.println("--------------User addUser-------------");
? ? ? }



? }


定义切面类


@Aspect//定义切面
@Component//声明这是一个组件
public class Interceptor {


? ? private final static Log log = LogFactory.getLog(Interceptor.class);
? ?
? ? /**
? ? * 这句话是方法切入点
? ? * 1 execution (* com.wangku.spring.service.impl..*.*(..))
? ? * 2 execution : 表示执行
? ? * 3 第一个*号 : 表示返回值类型, *可以是任意类型
? ? * 4 com.spring.service.impl : 代表扫描的包
? ? * 5 .. : 代表其底下的子包也进行拦截?
? ? * 6 第二个*号 : 代表对哪个类进行拦截,*代表所有类?
? ? * 7 第三个*号 : 代表方法? *代表任意方法
? ? * 8 (..) : 代表方法的参数有无都可以
? ? */
? ? //配置切入点,该方法无方法体,主要为方便同类中其他方法使用此处配置的切入点
? ? @Pointcut("execution (* com.gcx.service.impl..*.*(..))")
? ? private void aspect() {
? ? ? ? ? ? System.out.println("============进入aspect方法==============");
? ? }
? ? ? ? ? ?
? ? //配置环绕通知,使用在方法aspect()上注册的切入点
? ? @Around("aspect()")
? ? public void around(JoinPoint joinPoint){
? ? ? ? long start = System.currentTimeMillis();
? ? ? ? try {
? ? ? ? ? ? ((ProceedingJoinPoint) joinPoint).proceed();
? ? ? ? ? ? long end = System.currentTimeMillis();
? ? ? ? ? ? if(log.isInfoEnabled()){
? ? ? ? ? ? ? ? log.info("around " + joinPoint + "\tUse time : " + (end - start) + " ms!");//这里顺便记录下执行速度,可以作为监控
? ? ? ? ? ? }
? ? ? ? } catch (Throwable e) {
? ? ? ? ? ? long end = System.currentTimeMillis();
? ? ? ? ? ? if(log.isInfoEnabled()){
? ? ? ? ? ? ? ? log.info("around " + join

首页 上一页 1 2 下一页 尾页 1/2/2
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Spring AOP的两种代理 下一篇Spring AOP自定义注解方式实现日..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: