成都创新互联网站制作重庆分公司

使用Spring怎么实现动态代理

这篇文章将为大家详细讲解有关使用Spring怎么实现动态代理,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

为民勤等地区用户提供了全套网页设计制作服务,及民勤网站建设行业解决方案。主营业务为成都做网站、成都网站制作、民勤网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

基于jdk实现的动态代理

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;
/**
 * 动态代理模式类
 * 第一种代理模式:Jdk动态代理
 *  注意:实现InvocationHandler这个接口
 *
 *  基于接口的
 */
public class JdkDynamicProxy implements InvocationHandler {
 //定义需要代理的接口
 protected IModelMath iModelMath;

 //将需要代理的接口作为参数传入到动态代理设计模式类中
 public JdkDynamicProxy(IModelMath iModelMath){
  this.iModelMath = iModelMath;
 }
 /**
  * 生成代理对象
  * 使用java.lang.reflect.Proxy这个类调用newProxyInstance方法
  * 返回 动态代理类对象
  */
 public IModelMath iModelMathmethod(){
  IModelMath iModelMathProxy = (IModelMath) Proxy.newProxyInstance(iModelMath.getClass().getClassLoader(),
    iModelMath.getClass().getInterfaces(),
    this);
  return iModelMathProxy;
 }
 /**
  * 开始做代理的操作
  * Object proxy 代理对象的引用
  * Method method 当前执行的方法
  * Object[] args 当前执行方法的参数
  * 返回 与被代理对象返回的值相同
  */
 @Override
 public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
  System.out.println("你调用的方法为:"+method.getName());
  System.out.println("你调用的方法参数有:"+ Arrays.toString(args));
  Object invoke = method.invoke(iModelMath, args);
  System.out.println("方法的返回数据:"+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方式的动态代理
  * 测试
  */
 @Test
 public void testJdkDynamicProxy(){
  //需要被代理的动态对象
  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("实际方法的数据为:"+addition);
  System.out.println("实际方法的数据为:"+subtraction);
 }
}

基于gcLib实现的动态代理

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动态代理设计类
 * 前提必须要先导入 cglib 包
 * 基于 实现类的
 */
public class CglibDynamicProxy implements MethodInterceptor {
 //定义被代理的实现类(注意这 是实现类,不是接口)
 private ModelMath modelMath;

 //将被代理的对象作为参数 传入到 cglib动态代理设计类中
 public CglibDynamicProxy(ModelMath modelMath){
  this.modelMath = modelMath;
 }
 //生成代理对象
 public ModelMath getProxyModelMath(){
  //new 一个Enhancer对象
  Enhancer enhancer = new Enhancer();
  //指定他的父类(注意这 是实现类,不是接口)
  enhancer.setSuperclass(ModelMath.class);
  //指定真正做事情的回调方法
  enhancer.setCallback(this);
  //生成代理类对象
  ModelMath o = (ModelMath) enhancer.create();
  //返回
  return o;
 }
 /**
  * 执行被代理的任何方法,都会经过这个方法
  * @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 动态代理调用的方法名为:"+method.getName());
  System.out.println("通过gclib 动态代理调用的方法的参数包含:"+ Arrays.toString(objects));
  Object invoke = method.invoke(modelMath, objects);
  System.out.println("通过gclib 动态代理调用的方法返回的数据:"+ 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方式的动态代理
  * 测试
  */
 @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("执行减法得到的正式数据为:"+subtraction);
  System.out.println("执行加法得到的正式数据为:"+addition);
 }
}

关于使用Spring怎么实现动态代理就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


当前题目:使用Spring怎么实现动态代理
链接URL:http://cxhlcq.com/article/jddgis.html

其他资讯

在线咨询

微信咨询

电话咨询

028-86922220(工作日)

18980820575(7×24)

提交需求

返回顶部