AOP本质是拦截,拦截的本质是代理,代理分动态和静态,静态代理很简单,功能有限,应用不是很广泛,Spring中主要用的动态代理。
用Spring做开发,AOP的实现仅仅是编程实现一些接口,然后配置一下即可。这个可以参看“
Spring AOP 模型”一文。
为什么配置一下即可,究竟Spring框架内部做了如何的处理,实现了代理。下面可以看看下面的例子就明白了。
/**
* 被代理类
*/
public class MessageWriter{
/**
* 业务方法
*/
public void writeMessage() {
System.out.print( "World");
}
}
* 被代理类
*/
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.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();
}
}
/**
* 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
World
------------
Hello World!
Process finished with exit code 0
从中可以看到,Spring的代理很牛,不一定要求代理和被代理类都要实现同一个接口,Spring可以代理任何的类,当然final类除外,因为final类不允许继承。
本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/74942,如需转载请自行联系原作者