spring学习笔记(十三)

如果目标对象实现了接口,默认情况下采用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类

你可能感兴趣的:(spring,AOP,jdk,bean,Hibernate)