這篇文章將為大家詳細講解有關Spring中怎么實現(xiàn)動態(tài)代理,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
在龍里等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供網(wǎng)站設計制作、網(wǎng)站設計 網(wǎng)站設計制作定制網(wǎng)站設計,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,品牌網(wǎng)站建設,成都營銷網(wǎng)站建設,外貿網(wǎng)站制作,龍里網(wǎng)站建設費用合理。
基于jdk實現(xiàn)的動態(tài)代理
package com.proxy.daili;import com.proxy.daili.service.IModelMath;import java.lang.reflect.InvocationHandler;import java.lang.reflect.Method;import java.lang.reflect.Proxy;import java.util.Arrays;/** * 動態(tài)代理模式類 * 第一種代理模式:Jdk動態(tài)代理 * 注意:實現(xiàn)InvocationHandler這個接口 * * 基于接口的 */public class JdkDynamicProxy implements InvocationHandler { //定義需要代理的接口 protected IModelMath iModelMath; //將需要代理的接口作為參數(shù)傳入到動態(tài)代理設計模式類中 public JdkDynamicProxy(IModelMath iModelMath){ this.iModelMath = iModelMath; } /** * 生成代理對象 * 使用java.lang.reflect.Proxy這個類調用newProxyInstance方法 * 返回 動態(tài)代理類對象 */ public IModelMath iModelMathmethod(){ IModelMath iModelMathProxy = (IModelMath) Proxy.newProxyInstance(iModelMath.getClass().getClassLoader(), iModelMath.getClass().getInterfaces(), this); return iModelMathProxy; } /** * 開始做代理的操作 * Object proxy 代理對象的引用 * Method method 當前執(zhí)行的方法 * Object[] args 當前執(zhí)行方法的參數(shù) * 返回 與被代理對象返回的值相同 */ @Override public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { System.out.println("你調用的方法為:"+method.getName()); System.out.println("你調用的方法參數(shù)有:"+ Arrays.toString(args)); Object invoke = method.invoke(iModelMath, args); System.out.println("方法的返回數(shù)據(jù):"+invoke); return invoke; }}
package com.proxy.test;import com.proxy.daili.service.IModelMath;import com.proxy.daili.JdkDynamicProxy;import com.proxy.daili.service.ModelMath;import org.junit.Test;public class TestJDKDynamicProxy { /** * 使用jdk方式的動態(tài)代理 * 測試 */ @Test public void testJdkDynamicProxy(){ //需要被代理的動態(tài)對象 IModelMath imm = new ModelMath(); //代理對象 IModelMath math = new JdkDynamicProxy(imm).iModelMathmethod(); //通過代理對象做操作 int addition = math.addition(10, 2); int subtraction = math.subtraction(20, 19); System.out.println("實際方法的數(shù)據(jù)為:"+addition); System.out.println("實際方法的數(shù)據(jù)為:"+subtraction); }}
基于gcLib實現(xiàn)的動態(tài)代理
package com.proxy.daili;import com.proxy.daili.service.IModelMath;import com.proxy.daili.service.ModelMath;import net.sf.cglib.proxy.Enhancer;import net.sf.cglib.proxy.MethodInterceptor;import net.sf.cglib.proxy.MethodProxy;import java.lang.reflect.Method;import java.util.Arrays;/** * cglib動態(tài)代理設計類 * 前提必須要先導入 cglib 包 * 基于 實現(xiàn)類的 */public class CglibDynamicProxy implements MethodInterceptor { //定義被代理的實現(xiàn)類(注意這 是實現(xiàn)類,不是接口) private ModelMath modelMath; //將被代理的對象作為參數(shù) 傳入到 cglib動態(tài)代理設計類中 public CglibDynamicProxy(ModelMath modelMath){ this.modelMath = modelMath; } //生成代理對象 public ModelMath getProxyModelMath(){ //new 一個Enhancer對象 Enhancer enhancer = new Enhancer(); //指定他的父類(注意這 是實現(xiàn)類,不是接口) enhancer.setSuperclass(ModelMath.class); //指定真正做事情的回調方法 enhancer.setCallback(this); //生成代理類對象 ModelMath o = (ModelMath) enhancer.create(); //返回 return o; } /** * 執(zhí)行被代理的任何方法,都會經過這個方法 * @param o * @param method * @param objects * @param methodProxy * @return * @throws Throwable */ @Override public Object intercept(Object o, Method method, Object[] objects, MethodProxy methodProxy) throws Throwable { System.out.println("通過gclib 動態(tài)代理調用的方法名為:"+method.getName()); System.out.println("通過gclib 動態(tài)代理調用的方法的參數(shù)包含:"+ Arrays.toString(objects)); Object invoke = method.invoke(modelMath, objects); System.out.println("通過gclib 動態(tài)代理調用的方法返回的數(shù)據(jù):"+ invoke); return invoke; }}
package com.proxy.test;import com.proxy.daili.CglibDynamicProxy;import com.proxy.daili.service.ModelMath;import org.junit.Test;public class TestCgLibDynamicProxy { /** * 使用gclib方式的動態(tài)代理 * 測試 */ @Test public void testCglibDynamicProxy(){ ModelMath modelMath = new ModelMath(); ModelMath proxyModelMath = new CglibDynamicProxy(modelMath).getProxyModelMath(); int subtraction = proxyModelMath.subtraction(1, 44); int addition = proxyModelMath.addition(10, -1); System.out.println("執(zhí)行減法得到的正式數(shù)據(jù)為:"+subtraction); System.out.println("執(zhí)行加法得到的正式數(shù)據(jù)為:"+addition); }}
關于Spring中怎么實現(xiàn)動態(tài)代理就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。