生成代理类,并写入硬盘:配置系统属性sun.misc.ProxyGenerator.saveGeneratedFile为true,代理类生成时将自动将生成的代理类写入硬盘

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package cn.lut.dynamicproxy;
 
import java.lang.reflect.Proxy;
 
public class JdkDymamicPoxy {
    public static void main(String[] args) {
        //生成$Proxy0的class文件
        System.getProperties().put("sun.misc.ProxyGenerator.saveGeneratedFiles", "true");
         
        IHello iHello = (IHello) Proxy.newProxyInstance(IHello.class.getClassLoader(),
                new Class[]{IHello.class} ,
                new HWInvocationHandler(new Hello()));
        iHello.sayHello();
    }
}

报Exception in thread "main" java.lang.InternalError: I/O exception saving generated file:java.io.FileNotFoundException: com\sun\proxy\$Proxy0.class (系统找不到指定的路径。)异常时,在项目根目录下增加com/sun/proxy目录。

二、cglib动态代理生成.class文件

1、添加cglib依赖jar:cglib-3.1.jar、asm-3.1.jar

maven工程直接添加依赖:

1
2
3
4
5
<dependency>
      <groupid>cglib</groupid>
      cglib</artifactid>
      <version>3.1</version>
  </dependency>/

JDK动态代理生成.class文件和cglib动态代理生成.class文件

一、JDK动态代理生成.class文件

接口:

1
2
3
4
5
package cn.lut.dynamicproxy;
 
public interface IHello {
    void sayHello();
}

实现类:

1
2
3
4
5
6
7
8
9
package cn.lut.dynamicproxy;
 
public class Hello implements IHello {
 
    public void sayHello() {
        System.out.println("Hello,world!");
    }
 
}

InvoctionHandler实现:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
package cn.lut.dynamicproxy;
 
import java.lang.reflect.InvocationHandler;
import java.lang.reflect.Method;
 
public class HWInvocationHandler implements InvocationHandler {
    //目标对象
    private Object target;
     
    public HWInvocationHandler(Object target){
        this.target = target;
    }
     
    public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {
        System.out.println("------插入前置通知代码-------------");
        //执行相应的目标方法
        Object rs = method.invoke(target,args);
        System.out.println("------插入后置处理代码-------------");
        return rs;
    }
 
}

生成代理类,并写入硬盘:配置系统属性sun.misc.ProxyGenerator.saveGeneratedFile为true,代理类生成时将自动将生成的代理类写入硬盘

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
package cn.lut.dynamicproxy;
 
import java.lang.reflect.Proxy;
 
public class JdkDymamicPoxy {
    public static void main(String[] args) {
        //生成$Proxy0的class文件
        System.getProperties().put("sun.misc.ProxyGenerator.saveGeneratedFiles", "true");
         
        IHello iHello = (IHello) Proxy.newProxyInstance(IHello.class.getClassLoader(),
                new Class[]{IHello.class} ,
                new HWInvocationHandler(new Hello()));
        iHello.sayHello();
    }
}

报Exception in thread "main" java.lang.InternalError: I/O exception saving generated file:java.io.FileNotFoundException: com\sun\proxy\$Proxy0.class (系统找不到指定的路径。)异常时,在项目根目录下增加com/sun/proxy目录。

二、cglib动态代理生成.class文件

1、添加cglib依赖jar:cglib-3.1.jar、asm-3.1.jar

maven工程直接添加依赖:

1
2
3
4
5
<dependency>
      <groupid>cglib</groupid>
      cglib</artifactid>
      <version>3.1</version>
  </dependency>/

2、生成代理类

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
package cn.lut.dynamicproxy;
 
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 implements MethodInterceptor{ 
     private Enhancer enhancer = new Enhancer(); 
      
     public Object getProxy(Class<!--?--> clazz){ 
      //设置需要创建子类的类 
      enhancer.setSuperclass(clazz); 
      enhancer.setCallback(this); 
      //通过字节码技术动态创建子类实例 
      return enhancer.create(); 
     }
      
     //实现MethodInterceptor接口方法 
     public Object intercept(Object obj, Method method, Object[] args, 
       MethodProxy proxy) throws Throwable { 
      System.out.println("前置代理"); 
      //通过代理类调用父类中的方法 
      Object result = proxy.invokeSuper(obj, args); 
      System.out.println("后置代理"); 
      return result; 
     
    

3、具体实现类

添加System.in.read();,让程序一直运行,为生动.class文件作准备

1
2
3
4
5
6
7
8
9
10
11
12
13
package cn.lut.dynamicproxy;
 
import java.io.IOException;
 
public class DoCGLib {
    public static void main(String[] args) throws IOException { 
        CglibProxy proxy = new CglibProxy(); 
        //通过生成子类的方式创建代理类 
         Hello proxyImp = (Hello)proxy.getProxy(Hello.class); 
         proxyImp.sayHello();
         System.in.read();
    
}

4、运行HSDB工具

1)、打开cmd窗口,运行命令:java -classpath "%JAVA_HOME%/lib/sa-jdi.jar" sun.jvm.hotspot.HSDB

2)、点击file菜单下第一项


弹出

3)、打开任务管理器,找到当前运行java程序的进程号pid,输入到上图的文本框中,点击ok弹出

4)、点击工具(tools)菜单下的第一项Class Browser。弹出

5)、输入包名cn.lut.dynamic回车.

6)、点击Create .class File,在HSDB工具运行目录下下生产cglib动态代理类

获取动态代理生成的.class文件的更多相关文章

  1. JAVA-获取 JDK 动态代理生成的 Class 文件

    可指定路径 import sun.misc.ProxyGenerator; import java.io.FileOutputStream; import java.io.IOException; i ...

  2. Mybatis-简单基于源码了解获取动态代理对象

    这是我们要测试的代码 OderDao就是我们要需要获取的对象. 首先我们根据传入的参数,进入SqlSessionFactoryBuilder 中的对应的build 方法,第一步创键XMLConfigB ...

  3. C# Emit动态代理生成一个实体对象

    /// <summary> /// 使用Emit动态代理收集实体信息 /// </summary> /// <typeparam name="T"&g ...

  4. 通过模拟Mybatis动态代理生成Mapper代理类,讲解Mybatis核心原理

    本文将通过模拟Mybatis动态代理生成Mapper代理类,讲解Mybatis原理 1.平常我们是如何使用Mapper的 先写一个简单的UserMapper,它包含一个全表查询的方法,代码如下 pub ...

  5. 【SpringCloud原理】万字剖析OpenFeign之FeignClient动态代理生成源码

    年前的时候我发布两篇关于nacos源码的文章,一篇是聊一聊nacos是如何进行服务注册的,另一篇是一文带你看懂nacos是如何整合springcloud -- 注册中心篇.今天就继续接着剖析Sprin ...

  6. 输出cglib以及jdk动态代理产生的class文件

      --该设置用于输出jdk动态代理产生的类 System.getProperties().put("sun.misc.ProxyGenerator.saveGeneratedFiles&q ...

  7. java保存动态代理生成的类的class文件

    启动时加: -Dsun.misc.ProxyGenerator.saveGeneratedFiles=true

  8. java-jdk动态代理生成的代理类源码

    import com.zkn.newlearn.gof.proxyhandler.PersonInter; import java.lang.reflect.InvocationHandler; im ...

  9. 一文读懂Java中的动态代理

    从代理模式说起 回顾前文: 设计模式系列之代理模式(Proxy Pattern) 要读懂动态代理,应从代理模式说起.而实现代理模式,常见有下面两种实现: (1) 代理类关联目标对象,实现目标对象实现的 ...

随机推荐

  1. python的time

    有时候需要获取并格式化输出把当前时间,需要用到datetime的strftime方法 >>from datetime import datetime >>datetime.no ...

  2. 20175320 2018-2019-2 《Java程序设计》第4周学习总结

    20175320 2018-2019-2 <Java程序设计>第4周学习总结 教材学习内容总结 本周学习了教材的第五章的内容.在这章中介绍了子类与继承,着重讲了子类继承的规则以及使用sup ...

  3. LCA(Lowest Common Ancesor)

    LCA(Lowest Common Ancesor) 1.基于二分搜索算法 预处理father[v][k]表示v的2的k次方层祖先,时间复杂度是O(nlogn),每次查询的时间复杂度是O(logn), ...

  4. 程序中打印当前进程的调用堆栈(backtrace)

    为了方便调式程序,产品中需要在程序崩溃或遇到问题时打印出当前的调用堆栈.由于是基于Linux的ARM嵌入式系统,没有足够的空间来存放coredump文件. 实现方法,首先用__builtin_fram ...

  5. [redis] hiredis-vip 简单使用

    redis的C语言client,有几个:https://redis.io/clients#c 支持cluster的只有一个唯品会的版本:https://github.com/vipshop/hired ...

  6. python逻辑运算符规则

    逻辑运算符:or and not 优先级:()>not>and>or 举例子: Print(2>1 and 1<4 or 2<3 and 9>6 or 2&l ...

  7. 《Mysql 分区分表》

    一:分区/分表 为了什么? - 当MySQL单表的数据量过大时,数据库的访问速度会下降,需要处理大量数据,所以需要把数据分散存储. - 常用 "水平" 切分 二:MySQL常见的水 ...

  8. 学习笔记:Makefile的ifeq逻辑或,逻辑与的变通实现

        (1)ifeq的用法 ifeq ($(变量名), 变量值 ) ........ else ifeq ($(..), ..) ......... else ......... endif (2) ...

  9. Mac下搭建solr搜索引擎与PHP扩展开发(上)

    首先需要安装jdk,前往 https://www.oracle.com/technetwork/java/javase/downloads/jdk12-downloads-5295953.html 自 ...

  10. dll静态调用和动态调用

    动态链接库有2种连接方式,一种是通过库直接加入(又叫隐式加载或载入时加载),一种是在运行时加入.后者很好理解,比如LoadLibrary(),GetProcAddress()获取想要引入的函数,使用完 ...