spring cglib 與 jdk 動態(tài)代理
1. 概述
JDK動態(tài)代理是利用java反射機制 生成一個實現(xiàn)接口的匿名類, 在調用具體方法前調用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.");
}
}
以上就是本文的全部內容,希望本文的內容對大家的學習或者工作能帶來一定的幫助,同時也希望多多支持腳本之家!
- Spring實戰(zhàn)之使用TransactionProxyFactoryBean實現(xiàn)聲明式事務操作示例
- Spring基于ProxyFactoryBean創(chuàng)建AOP代理
- Springboot源碼 AbstractAdvisorAutoProxyCreator解析
- Spring AOP中的JDK和CGLib動態(tài)代理哪個效率更高?
- 詳解Spring的兩種代理方式:JDK動態(tài)代理和CGLIB動態(tài)代理
- Spring學習之動態(tài)代理(JDK動態(tài)代理和CGLIB動態(tài)代理)
- Spring中的兩種代理JDK和CGLIB的區(qū)別淺談
- Spring如何基于Proxy及cglib實現(xiàn)動態(tài)代理
相關文章
IDEA 集成 Docker 插件一鍵部署 SpringBoot 應用
通過本文介紹的方法,我們期望能幫助開發(fā)者更輕松地在IDEA中實現(xiàn)Spring Boot應用的Docker化部署,為現(xiàn)代軟件開發(fā)提供更便捷的解決方案,感興趣的朋友一起看看吧2023-11-11
SpringBoot熔斷機制之CircuitBreaker詳解
這篇文章主要介紹了SpringBoot熔斷機制之CircuitBreaker詳解,SpringBoot的熔斷機制在微服務架構中扮演著重要角色,其中CircuitBreaker是其核心機制之一,用于防止服務的異常狀態(tài)影響到整個系統(tǒng)的運作,需要的朋友可以參考下2023-10-10
PowerJob LockService方法工作流程源碼解讀
這篇文章主要為大家介紹了PowerJob LockService方法工作流程源碼解讀,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2024-01-01
解決Springboot配置excludePathPatterns不生效的問題
這篇文章主要介紹了解決Springboot配置excludePathPatterns不生效的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
MyBatis中的collection兩種使用方法及效率比較
collection主要是應對表關系是一對多的情況,本文主要介紹了MyBatis中的collection兩種使用方法及效率比較,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-06-06
Spring Boot使用Thymeleaf + Gradle構建war到Tomcat
今天小編就為大家分享一篇關于Spring Boot使用Thymeleaf + Gradle構建war到Tomcat,小編覺得內容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12

