这篇文章主要介绍了SpringAop实现原理及代理模式是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringAop实现原理及代理模式是什么文章都会有所收获,下面我们一起来看看吧。
Spring Aop的原理
Spring的AOP就是通过动态代理实现的。当为某个Bean或者某些Bean配置切面时,Spring会为其创建代理对象,当调用该对象的某个方法时,实际是调用生成的代理类的对象方法。Spring的Aop主要是使用了两个动态代理,分别是JDK的动态代理和CGLIB动态代理。
1. JDK动态代理
如果代理类实现了接口,Spring默认会使用JDK动态代理。JDK的动态代理是基于反射实现。JDK通过反射,生成一个代理类,这个代理类实现了原来那个类的全部接口,并对接口中定义的所有方法进行了代理。当我们通过代理对象执行原来那个类的方法时,代理类底层会通过反射机制,调用我们实现的InvocationHandler接口的invoke方法。
public interface Person { void say();} * 接口实现类public class Man implements Person { private String word; public Man(String word){ this.word = word; } public Man(){ public void say(){ System.out.println("Man Can Say " + word);public class ManJDKProxy implements InvocationHandler { private Object o; public Object bind(Object o){ this.o = o; return Proxy.newProxyInstance(o.getClass().getClassLoader(), o.getClass().getInterfaces(), this); @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("JDK Proxy Design"); return method.invoke(o, args);public interface Person { void say();} * 接口实现类public class Man implements Person { private String word; public Man(String word){ this.word = word; } public Man(){ public void say(){ System.out.println("Man Can Say " + word);public class ManCGLIBProxy { public Object bind(Object target){ Enhancer enhancer = new Enhancer(); enhancer.setSuperclass(target.getClass()); enhancer.setCallback(new MethodInterceptor() { @Override public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable { System.out.println("CGLIB Proxy Design"); return method.invoke(target, objects); } }); return enhancer.create();/** * CGLIB动态代理public class ProxyDesign_3 { public static void main(String[] args) { Man man = new Man("Hello"); Person p = (Person)new ManCGLIBProxy().bind(man); p.say();
* CGLiB动态代理的优缺点
优点:
1. 使用CGLiB代理的类,不需要实现接口,因为CGLib生成的代理类是直接继承自需要被代理的类
2. 因为CGLiB实现方式是重写父类的方法,所以对final方法,或者private方法是没有办法代理的
3. CGLiB是通过修改字节码生成的代理类,所以CGLib执行代理方法的效率要高于JDK的动态代理
缺点:
1. 因为CGLiB实现方式是重写父类的方法,所以对final方法,或者private方法是没有办法代理的
2. 因为CGLiB生成代理类的方式是通过操作字节码(asm工具包),这种生成的代理类的方式比JDK通过反射生成代理类的方式的效率低
3. Spring项目中如何强制使用CGLIB代理方式
* xml方式
<!-- aop:config用来在xml中配置切面,指定proxy-target-class="true" --><aop:config proxy-target-class="true"><!-- AOP相关配置 --></aop:config>
* @Aspect注解方式
<!-- 将proxy-target-class配置设置为true --><aop:aspectj-autoproxy proxy-target-class="true"/>
* 配置类注解方式
添加@EnableAspectJAutoProxy(proxyTargetClass = true)
关于“SpringAop实现原理及代理模式是什么”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“SpringAop实现原理及代理模式是什么”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注编程网行业资讯频道。