spring-aop-aspectj-case

[b]AOP概念[/b]:面向切面编程。

[b]spring 集成AOP:[/b]
1、spring 有自己的aop实现ProxyFactory ,和 ProxyFactoryBean 。
2、spring 集成AspectJ实现的Aop。

[b]spring AOP的使用场景:[/b]
在spring中 事务处理和rpc调用都大量的使用了aop,在低入侵监控方面都有大量应用。

[b]spring以来的底层技术[/b]:Jdk代理和Cglib代理技术。

[b]spring 支持的aop应用实现方式有以下几种:[/b]
1、基于ProxyFactory 的编程方式的aop实现。
2、基于ProxyFactoryBean 配置的,走spring ioc 路的实现方式。
3、基于以上方式自动创建代理 BeanNameAutoProxyCreator +Advice 和 DefaultAdvisorAutoProxyCreator + Advisor方式。
4、基于AspectJProxyFactory + AspectJ注解的编程的方式。
5、基于AspectJ 注解 + AnnotationAwareAspectJAutoProxyCreator的方式。
6、基于Schema + Aspectj注解语言的 Aop:config方式。


下面举例 基于AspectJ 注解的方式,实现一个方法耗时统计的功能:


/**
* aspectj 基于注解的方式
* @author wangxinchun
*/
public @interface MethodExecuteTimes {}



[b]定义需要代理的业务方法[/b]

@Service
public class LoginService implements ILoginService {

@MethodExecuteTimes
public void regist(String username, String password, String email, int age) {
System.out.println(Arrays.toString(new Object[]{username,password,age}));
}

}


[b]定义切面[/b]

package org.job.user.aop;

import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.springframework.stereotype.Component;

/**
* 定义切面 (关注方法上有注解:org.job.user.MethodExecuteTimes)
* @author wangxinchun
*/
@Aspect
@Component
public class RegisterMonitorAspectj {
public static final ThreadLocal<Long> time = new ThreadLocal<Long>();
/** 方法调用前执行*/
@Before("@annotation(org.job.user.MethodExecuteTimes))")
public void before() {
time.set(System.currentTimeMillis());
System.out.println("invoke before ");
}
/** 方法调用后执行(如果方法抛出异常,此方法不会执行)*/
@AfterReturning("@annotation(org.job.user.MethodExecuteTimes))")
public void after() {
System.out.println("invoke after ");
System.out.println("times : "+(System.currentTimeMillis() - time.get()));
}
/** 方法调用finally 执行*/
@After("@annotation(org.job.user.MethodExecuteTimes))")
public void _final(){
System.out.println("final");
}
}


applicationContext.xml 配置启动AspectJ

<!-- <aop:aspectj-autoproxy/> -->
<bean class="org.springframework.aop.aspectj.annotation.AnnotationAwareAspectJAutoProxyCreator"/>


测试用例

@Test
public void testRegister() {
LoginService loginService = new LoginService();
AspectJProxyFactory factory = new AspectJProxyFactory();
factory.setTarget(loginService);
factory.addAspect(RegisterMonitorAspectj.class);


ILoginService proxy = factory.getProxy();
proxy.regist("admin", "123456","xinchun.wang@qunar.com",10);
}


具体实现看附件~
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值