如果目标对象实现了接口,默认情况下采用jdk动态代理机制实现aop.
如果目标对象实现了接口,可以强制spring采用CGLIB生成代理.
具体做法:
引入CGLIB库(Hibernate采用的是CGLIB代理),在配置文件中增加
cglib-nodep-2.1_3.jar
<aop:aspectj-autoproxy proxy-target-class="true" />
AOP :默认采用jdk的动态代理.
{ 两种方式 实现aop 注解
} 配置文件
静态代理:代理类是自己创造的.
动态代理: jdk的动态代理,代理类是动态生成的,而且jdk的动态代理必须实现要代理类的接口.实现方法的拦截.
类代理:CGLIB 对没有接口的类进行代理,必须用CGLIB .原理是 继承该类然后自己扩展.
实验:自己做spring aop jdk动态代理和cglib代理 cglib出来的代理类是不是属于被代理类
Cglib 无法为final的类实现代理
System.out.println("=="+ (userDao instanceof UserDaoImpl)); 使用aop 默认代理出来的类 属于接口,不属于被代理类,而用CGLIB方式得到的代理类是在原来类继承的,属于被代理类
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.0.xsd"> <!--如果目标对象实现了接口,可以强制使用CGLIB--> <aop:aspectj-autoproxy proxy-target-class="true" /> <aop:config> <aop:aspect id="MySecurty" ref="MySecurtyMangerImp"> <aop:pointcut id="allAddMethod" expression="execution(* add*(..))||execution(* del*(..))" /> <aop:before pointcut-ref="allAddMethod" method="checkSecurity"/> </aop:aspect> </aop:config> <bean id="MySecurtyMangerImp" class="zhc.love.dj.test.MySecurtyMangerImp"></bean> <bean id="UserManger" class="zhc.love.dj.test.UserMangerImp"></bean> </beans>
和上一个例子主要区别在这个xml 的那句话,有了这句话,强制使用cglib类