Spring AOP 本质
2015-12-07 01:08
453 查看
AOP本质是拦截,拦截的本质是代理,代理分动态和静态,静态代理很简单,功能有限,应用不是很广泛,Spring中主要用的动态代理。
用Spring做开发,AOP的实现仅仅是编程实现一些接口,然后配置一下即可。这个可以参看“Spring AOP
模型”一文。
为什么配置一下即可,究竟Spring框架内部做了如何的处理,实现了代理。下面可以看看下面的例子就明白了。
例子中用ProxyFactory类来创建目标对象的代理,同时织入通知。通过调用addAdvice(new MessageDecorator()),把MessageDecorator通知传给ProxyFactory,然后通过调用setTarget(target)设定织入的目标对象。设定了目标对象,也织入了通知,就可以调用ProxyFactory.getProxy()来获得一个代理对象。
运行结果:
- Using JDK 1.4 collections
World
------------
Hello World!
Process finished with exit code 0
从中可以看到,Spring的代理很牛,不一定要求代理和被代理类都要实现同一个接口,Spring可以代理任何的类,当然final类除外,因为final类不允许继承。
用Spring做开发,AOP的实现仅仅是编程实现一些接口,然后配置一下即可。这个可以参看“Spring AOP
模型”一文。
为什么配置一下即可,究竟Spring框架内部做了如何的处理,实现了代理。下面可以看看下面的例子就明白了。
/** * 被代理类 */ public class MessageWriter{ /** * 业务方法 */ public void writeMessage() { System.out.print("World"); } }
import org.aopalliance.intercept.MethodInterceptor; import org.aopalliance.intercept.MethodInvocation; /** * 实现包围通知,实际就是方法拦截器,MethodInterceptor是AOP联盟定义的接口. */ public class MessageDecorator implements MethodInterceptor { public Object invoke(MethodInvocation invocation) throws Throwable { System.out.print("Hello "); Object retVal = invocation.proceed(); System.out.println("!"); return retVal; } }
import org.springframework.aop.framework.ProxyFactory; /** * AOP测试 */ public class HelloWorldAOPExample { public static void main(String[] args) { //目标对象(被代理的对象) MessageWriter target = new MessageWriter(); //产生一个代理工厂 ProxyFactory pf = new ProxyFactory(); //添加代理工厂的拦截器 pf.addAdvice(new MessageDecorator()); //设置被代理对象 pf.setTarget(target); //获取一个代理实例 MessageWriter proxy = (MessageWriter) pf.getProxy(); //从目标对象直接输出信息 target.writeMessage(); System.out.println("\n------------"); //从代理对象输出信息 proxy.writeMessage(); } }
例子中用ProxyFactory类来创建目标对象的代理,同时织入通知。通过调用addAdvice(new MessageDecorator()),把MessageDecorator通知传给ProxyFactory,然后通过调用setTarget(target)设定织入的目标对象。设定了目标对象,也织入了通知,就可以调用ProxyFactory.getProxy()来获得一个代理对象。
运行结果:
- Using JDK 1.4 collections
World
------------
Hello World!
Process finished with exit code 0
从中可以看到,Spring的代理很牛,不一定要求代理和被代理类都要实现同一个接口,Spring可以代理任何的类,当然final类除外,因为final类不允许继承。
相关文章推荐
- java基础篇-jar打包
- 使用VisualVM查看Java Heap Dump
- Java计算1-n个数阶乘的和
- JAVA的ByteArrayOutputStream
- 由Handler引起内存泄露引发的java类设计思考
- JAVA简单的文件I/O操作实例
- 栈和队列之用java实现栈
- JAVA的FileOutput/InputStream使用实例
- java并发编程实战学习笔记之对象的组合与基础构建模块
- Plupload上传组件 + javaweb实现上传源码以及DEMO
- Java集合类
- Win7使用Hadoop2.7.1-eclipse-plugin插件(1)
- Eclipse在异常关闭后,启动闪退的解决办法
- The road from my heart to java chapter5
- jxl生成excel 并下载
- 基于注解的SpringMVC
- SpringMVC 处理异常的4种方式
- Hibernate-validation 单独javabean校验
- Java 字符串分割
- Java快速排序