Unable to apply any optimisations to advised method 信息解析

在Spring3中使用CgLib动态代理时出现类似以下日志:
[DEBUG] 2011-06-16 23:23:54,457 org.springframework.aop.framework.Cglib2AopProxy - <Unable to apply any 
optimisations to advised method: public java.lang.Object 
org.workin.orm.PersistenceProvider.merge(java.lang.Object)> 
[DEBUG] 2011-06-16 23:23:54,457 org.springframework.aop.framework.Cglib2AopProxy - <Unable to apply any 
optimisations to advised method: public void 
org.workin.orm.PersistenceProvider.refresh(java.lang.Object)> 


首先了解spring对AOP的支持 :

1、如果目标对象实现了接口,默认会采用JDK的动态代理机制实现AOP
2、如果目标对象实现了接口,可以强制使用CGLIB实现AOP
3、如果目标对象没有实现接口,必须使用CGLIB生成代理,spring会自动在CGLIB和JDK动态代理之间切换

4.如何强制使用CGLIB生成代理?
* 添加CGLIB库,SPRING_HOME/lib/cglib/*.jar
* 在spring的配置文件中加入:
<aop:aspectj-autoproxy proxy-target-class="true"/>


JDK代理和CGLIB代理的区别?
* JDK代理只能对实现了接口的类生成代理,而不能针对类
* CGLIB是针对类实现代理的,主要对指定的类生成一个子类,并覆盖其中的方法,
  因为是继承,所以不能使用final来修饰类或方法

解决该信息的处理建议:
1、如果一定要用不实现接口的类。
  建议尽量用Set注入,尽可能不用构造方法注入。
2、最好还是定义个接口,然后实现这个接口。
  这样不管是什么注入,都没问题了。
因为PersistenceProvider没有实现接口,目前是用@Repository注解注入的,所以将该注解去掉,改为set注入或者在xml中属性注入,就OK了。

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