spring cglib 與 jdk 動態(tài)代理
1. 概述
JDK動態(tài)代理是利用java反射機制 生成一個實現(xiàn)接口的匿名類, 在調(diào)用具體方法前調(diào)用InvocationHandler來處理
Cglib動態(tài)代理是 利用asm開源包 把被代理類的class文件加載進來 通過修改其字節(jié)碼生成子類來處理
如果目標對象實現(xiàn)了接口 那么默認使用jdk代理(可以強制使用cglib代理)
如果沒有實現(xiàn)接口 必須使用cglib代理
強制使用cglib代理需要
*引入cglibjar包
*配置spring <aop:aspectj-autoproxy proxy-target-class="true"/>
cglib因為是動態(tài)生成被代理類的子類 并覆蓋被代理類的方法 來實現(xiàn)的 所以 被代理方法不要使用final修飾
2. 代碼示例
2.1 cglib代理類
package com.rocky.spring; import java.lang.reflect.Method; import net.sf.cglib.proxy.Enhancer; import net.sf.cglib.proxy.MethodInterceptor; import net.sf.cglib.proxy.MethodProxy; public class CglibProxy { public static void main(String[] args) { final UserService service = new UserService(); Enhancer hancer = new Enhancer(); hancer.setSuperclass(service.getClass()); hancer.setCallback(new MethodInterceptor(){ @Override public Object intercept(Object proxy, Method method, Object[] arg2, MethodProxy arg3) throws Throwable { System.out.println("增強前 ... Cglib"); Object invoke = method.invoke(service, arg2); System.out.println("增強后 ... Cglib"); return invoke; }}); UserService userService = (UserService) hancer.create(); userService.sayHello(); } } //需要引入cglib-2.2.jar 和org.objectweb.asm-3.3.1.jar //輸出 //增強前 ... Cglib //this userService works.... //增強后 ... Cglib
被代理類UserService
package com.rocky.spring; public class UserService { public void sayHello(){ System.out.println("this userService works...."); } }
2.2 jdk代理接口
package com.rocky.spring; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; public class JdkProxy { public static void main(String[] args) { final ActorService service = new ActorServiceImpl(); ActorService actorService = (ActorService) Proxy.newProxyInstance( service.getClass().getClassLoader(), service.getClass() .getInterfaces(), new InvocationHandler() { @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("增強前...jdk"); Object invoke = method.invoke(service, args); System.out.println("增強后...jdk"); return invoke; } }); actorService.sayHi(); } } //增強前...jdk //Honestly, I do the work. //增強后...jdk
被代理接口及實現(xiàn)類
package com.rocky.spring; public interface ActorService { public void sayHi(); } ----------------- package com.rocky.spring; public class ActorServiceImpl implements ActorService { @Override public void sayHi() { doSomething(); } private void doSomething() { System.out.println("Honestly, I do the work."); } }
以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
- Spring實戰(zhàn)之使用TransactionProxyFactoryBean實現(xiàn)聲明式事務(wù)操作示例
- Spring基于ProxyFactoryBean創(chuàng)建AOP代理
- Springboot源碼 AbstractAdvisorAutoProxyCreator解析
- Spring AOP中的JDK和CGLib動態(tài)代理哪個效率更高?
- 詳解Spring的兩種代理方式:JDK動態(tài)代理和CGLIB動態(tài)代理
- Spring學(xué)習(xí)之動態(tài)代理(JDK動態(tài)代理和CGLIB動態(tài)代理)
- Spring中的兩種代理JDK和CGLIB的區(qū)別淺談
- Spring如何基于Proxy及cglib實現(xiàn)動態(tài)代理
相關(guān)文章
IDEA 集成 Docker 插件一鍵部署 SpringBoot 應(yīng)用
通過本文介紹的方法,我們期望能幫助開發(fā)者更輕松地在IDEA中實現(xiàn)Spring Boot應(yīng)用的Docker化部署,為現(xiàn)代軟件開發(fā)提供更便捷的解決方案,感興趣的朋友一起看看吧2023-11-11SpringBoot熔斷機制之CircuitBreaker詳解
這篇文章主要介紹了SpringBoot熔斷機制之CircuitBreaker詳解,SpringBoot的熔斷機制在微服務(wù)架構(gòu)中扮演著重要角色,其中CircuitBreaker是其核心機制之一,用于防止服務(wù)的異常狀態(tài)影響到整個系統(tǒng)的運作,需要的朋友可以參考下2023-10-10PowerJob LockService方法工作流程源碼解讀
這篇文章主要為大家介紹了PowerJob LockService方法工作流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01解決Springboot配置excludePathPatterns不生效的問題
這篇文章主要介紹了解決Springboot配置excludePathPatterns不生效的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10MyBatis中的collection兩種使用方法及效率比較
collection主要是應(yīng)對表關(guān)系是一對多的情況,本文主要介紹了MyBatis中的collection兩種使用方法及效率比較,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-06-06Eclipse、MyEclipse 導(dǎo)入svn項目具體步驟
這篇文章主要介紹了Eclipse、MyEclipse 導(dǎo)入svn項目具體步驟的相關(guān)資料,需要的朋友可以參考下2016-10-10Spring Boot使用Thymeleaf + Gradle構(gòu)建war到Tomcat
今天小編就為大家分享一篇關(guān)于Spring Boot使用Thymeleaf + Gradle構(gòu)建war到Tomcat,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12