当前位置: 移动技术网 > IT编程>开发语言>Java > Spring AOP代理详细介绍

Spring AOP代理详细介绍

2017年12月08日  | 移动技术网IT编程  | 我要评论

spring aop代理详细介绍

前言:

一开始我对spring aop还是属于一知半解的状态,这几天遇到一个问题,加上又查看了一些spring相关知识,感觉对这个问题有了更深刻的认识。所以写下来分享一下。

我们知道,spring支持多种aop方式,spring自己的基于代理的aop和aspectj的基于编织(weaving)的aop。如果一个类实现了一个或多个接口,那么spring就会使用默认的jdk动态代理,如果没有实现任何接口,就会使用cglib来代理。当然我们也可以手动改变这些设置。这也是比较容易掉坑的部分,如果设置错了代理方式,那么在依赖注入的时候,就会出现beannotofrequiredtypeexception。

首先来说说jdk动态代理,这种代理方式会代理接口。具体的说,对象a实现了接口a和接口b。spring会创建一个代理对象,这个对象实现了接口a和接口b,但是需要注意,代理对象和对象a没有任何关系。我们可以把代理对象当做任何一个接口来使用,但是无法将代理对象转换成类a来使用。

假如我们现在有以下一个接口和类。

public interface interfacea {
}

public class classa implements interfacea {
}

然后我们使用依赖注入来获取对象a的话就只能类型只能为interfacea,如果类型写成classa就会出现beannotofrequiredtypeexception。因为这里实际注入的对象是一个实现了interfacea的代理对象,和classa没有任何关系。这种情况是spring建议我们的,使用接口来进行编程。如果必须注入类的话,就需要使用cglib来代理,也就是在aop配置中添加proxy-target-class="true"。

然后再来说说cglib代理。这是一个代理类的方式,所以如果我们使用这种代理,上面的情况下既可以注入classa,又可以注入interfacea。

最后再来说说aspectj的基于编织的aop。所谓编织,就是在生成的类文件中增加或修改代码,有编译时编织和运行时编织之分。如果你使用aspectj并反编译一个编织了的类,就会发现这个类文件被aspectj修改了。由于aspectj的基于编织的特性,所以基于代理的aop的自引用、两种代理的问题,在aspectj中都不会出现。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网