Java类如何实现一个类的障眼法(JadClipse的bug)

 更新时间:2022年12月29日 09:06:21   作者:DayDayUp丶  
这篇文章主要介绍了Java类实现一个类的障眼法(JadClipse的bug),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

Java类实现一个类的障眼法

众所周知,Java的类只能去实现(implements)一个或多个接口,而不能去实现(implements)一个类。

然而,有的朋友可能会注意到这样的现象,在eclipse里,查看JDBC的com.mysql.cj.Driver.class和它的父类com.mysql.cj.NonRegisteringDriver.class源码,鼠标放到NonRegisteringDriver所实现的接口名Driver上,确确实实地看到tooltip提示“com.mysql.cj.Driver”

如下图所示:

什么鬼?Java类还可以实现类了吗?老师不是这么教的啊。。试试能不能鼠标点进去 。。

竟然真的点进来了。。 定睛一看,这个Driver继承了NonRegisteringDriver,而NonRegisteringDriver又实现了Driver,这是什么操作?其实,这个是个障眼法而已,类怎么能实现另一个类呢?那到底是谁搞的鬼?答案是eclipse的反编译插件JadClipse

一般情况下,我们需要在IDE中较为方便地查看第三方jar包的源代码时,一种方法是,可以安装反编译插件JadClipse等,但是需要注意的是,这些反编译插件是有漏洞的,不然所有的class文件都能被无误地反编译出来,那所有就都是开源的了。

那怎么确定反编译是否有错?可以查看反编译后的代码末尾,都会有反编译过程的报告信息和错误异常,如下:

 /*jadclipse*/// Decompiled by Jad v1.5.8g. Copyright 2001 Pavel Kouznetsov.
 
package com.mysql.cj.jdbc;
 
import com.mysql.cj.*;
import xx..;
 
// Referenced classes of package com.mysql.cj.jdbc:
//            ConnectionImpl, JdbcPropertySetImpl, AbandonedConnectionCleanupThread, JdbcConnection
 
public class NonRegisteringDriver
    implements Driver
{
    ...
}
 
/*
	DECOMPILATION REPORT
	Decompiled from: D:\maven-repository\mysql\mysql-connector-java\8.0.13\mysql-connector-java-8.0.13.jar
	Total time: 55 ms
	Jad reported messages/errors:
Couldn't fully decompile method cleanup
Couldn't resolve all exception handlers in method cleanup
Couldn't fully decompile method connect
Couldn't resolve all exception handlers in method connect
    Exit status: 0
	Caught exceptions:
*/

很明显看到,反编译类com.mysql.cj.jdbc.NonRegisteringDriver的时候出现了一些错误。

Jad的bug和限制

  • 包含有内部类,则jad处理构造函数的参数时会出错;
  • 不支持zip和jar包(注:如果使用Eclipse插件,则很容易得到包中的某个类的反编译代码);
  • 当有标签块,嵌套循环中有break/continue,有goto语句的时候,会提示信息“Couldn't fully decompile method <name>”;当有try-catch-finally语句的时候会提示信息“Couldn't resolve all exception handlers in method <name>”;
  • 目前,Jad忽略了行号表属性和源文件属性的内容;
  • Jad不能处理继承信息,总是把java.lang.Object作为两个不同类的通用父类,需要的时候做强制转换;
  • Jad对inlined functions处理不好。

所以说,查看反编译出来的源码时,眼见不一定为真。想要查看源码,最靠谱的还是尽量找到源码包关联起来。

最终,下载并关联源码包,发现com.mysql.cj.jdbc.NonRegisteringDriver真正实现的是java.sql.Driver。

我的环境如下

  • eclipse Version: Mars.2 Release (4.5.2)
  • JadClipse Version: v1.5.8g
  • mysql-connector-java.jar Version: 8.0.13

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • springboot整合jasypt的详细过程

    springboot整合jasypt的详细过程

    这篇文章主要介绍了springboot整合jasypt的详细过程,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2024-02-02
  • 解决在微服务环境下远程调用feign和异步线程存在请求数据丢失问题

    解决在微服务环境下远程调用feign和异步线程存在请求数据丢失问题

    这篇文章主要介绍了解决在微服务环境下远程调用feign和异步线程存在请求数据丢失问题,主要包括无异步线程得情况下feign远程调用,异步情况下丢失上下文问题,需要的朋友可以参考下
    2022-05-05
  • Java的注解原理详解

    Java的注解原理详解

    这篇文章主要介绍了Java的注解原理详解,注解是JDK1.5引入的新特性,包含在java.lang.annotation包中,它是附加在代码中的一些元信息,将一个类的外部信息与内部成员联系起来,在编 译、运行时进行解析和使用,需要的朋友可以参考下
    2023-10-10
  • springboot整合消息队列RabbitMQ

    springboot整合消息队列RabbitMQ

    这篇文章主要介绍了springboot整合消息队列RabbitMQ,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-08-08
  • Java常用工具类汇总 附示例代码

    Java常用工具类汇总 附示例代码

    这篇文章主要介绍了Java常用工具类,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着我来一起学习学习吧,希望能给你带来帮助
    2021-06-06
  • springboot详解实现车险理赔信息管理系统代码

    springboot详解实现车险理赔信息管理系统代码

    本系统基于Springboot开发实现了一个为用户车险进行理赔信息管理的一个信息化管理系统,核心的业务主要是用户申请保险理赔,管理员审核进入理赔程序,事故调查员对事故进行调查和现场勘察,这其中共涉及到三类用户,购买保险的客户,事故调查员和系统管理员
    2022-06-06
  • SpringBoot 整合 ElasticSearch操作各种高级查询搜索

    SpringBoot 整合 ElasticSearch操作各种高级查询搜索

    这篇文章主要介绍了SpringBoot 整合 ES 进行各种高级查询搜索的实践记录,本文主要围绕 SpringBoot 整合 ElasticSearch 进行各种高级查询的介绍,需要的朋友可以参考下
    2022-06-06
  • 一文了解Java动态代理的原理及实现

    一文了解Java动态代理的原理及实现

    动态代理指的是,代理类和目标类的关系在程序运行的时候确定的,客户通过代理类来调用目标对象的方法,是在程序运行时根据需要动态的创建目标类的代理对象。本文将通过案例详细讲解一下Java动态代理的原理及实现,需要的可以参考一下
    2022-07-07
  • RabbitMQ开启SSL与SpringBoot连接测试的配置方法

    RabbitMQ开启SSL与SpringBoot连接测试的配置方法

    本文基于 CentOS 7 + Git + OpenSSL + yum 安装的 RabbitMQ,需要读者提交安装好。其他方式也可变通参考本文。对RabbitMQ开启SSL与SpringBoot连接测试相关知识感兴趣的朋友一起看看吧
    2022-01-01
  • springsecurity 登录认证流程分析一(ajax)

    springsecurity 登录认证流程分析一(ajax)

    这篇文章主要介绍了springsecurity 登录认证一(ajax篇),本文通过实例代码图文相结合给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-08-08

最新评论