如何防止JAVA程序源代码被反编译

如题所述

而这样的文件是存在规律的,经过反编译工具是可以还原回来的。例如Decafe、FrontEnd,YingJAD和Jode等等软件。下面是《Nokia中Short数组转换算法》类中Main函数的ByteCode:0 ldc #162 invokestatic #185 astore_16 return其源代码是:short [] pixels = parseImage("/ef1s.png");我们通过反编译工具是可以还原出以上源代码的。而通过简单的分析,我们也能自己写出源代码的。第一行:ldc #16ldc为虚拟机的指令,作用是:压入常量池的项,形式如下ldc index这个index就是上面的16,也就是在常量池中的有效索引,当我们去看常量池的时候,我们就会找到index为16的值为String_info,里面存了/ef1s.png.所以这行的意思就是把/ef1s.pn作为一个String存在常量池中,其有效索引为16。第二行:2 invokestatic #18invokestatic为虚拟机指令,作用是:调用类(static)方法,形式如下invokestatic indexbyte1 indexbyte2其中indexbyte1和indexbyte2必须是在常量池中的有效索引,而是指向的类型必须有Methodref标记,对类名,方法名和方法的描述符的引用。所以当我们看常量池中索引为18的地方,我们就会得到以下信息:Class Name : cp_info#1Name Type : cp_info#191 和19都是常量池中的有效索引,值就是右边<中的值,再往下跟踪我就不多说了,有兴趣的朋友可以去JAVA虚拟机规范。这里我简单介绍一下parseImage(Ljava/lang/String;)[S 的意思。这就是parseImage这个函数的运行,我们反过来看看parseImage的原型就明白了short [] parseImage(String)那么Ljava/lang/String;就是说需要传入一个String对象,而为什么前面要有一个L呢,这是JAVA虚拟机用来表示这是一个Object。如果是基本类型,这里就不需要有L了。然后返回为short的一维数组,也就是对应的[S。是不是很有意思,S对应着Short类型,而“[”对应一维数组,那有些朋友要问了,两维呢,那就“[[”,呵呵,是不是很有意思。好了,调用了函数,返回的值要保存下来吧。那么就是第三行要做的事情了。
温馨提示:内容为网友见解,仅供参考
无其他回答

一些防止 Java 代码被反编译的方法
防止 Java 代码被反编译的方法有多种,这些方法并非绝对安全,但可以增加反编译难度。常见的方法包括隔离 Java 程序、对 Class 文件进行加密、将程序转换成本地代码以及代码混淆等。隔离 Java 程序的方法是将关键的 Java Class 放在服务器端,客户端通过访问服务器的相关接口获得服务,而非直接访问 Class ...

Java jar 如何防止被反编译
隔离Java程序是最基本的保护方法,主要通过将关键的Java Class程序部署在服务器端,客户端通过访问服务器接口获取服务,避免直接访问Class文件,以降低反编译难度。这种方法适用于服务器端应用,但不适合单机运行的程序。对Class文件进行加密则通过加解密技术,使黑客难以直接反编译Class文件。加密类文件可以在客...

怎么防止Java开发出来的程序被别人反编译
将程序转换成本地代码也是一种防止反编译的有效方法。因为本地代码往往难以被反编译。开发人员可以选择将整个应用程序转换成本地代码,也可以选择关键模块转换。如果仅仅转换关键部分模块,Java程序在使用这些模块时,需要使用JNI技术进行调用。4、代码混淆 代码混淆是对Class文件进行重新组织和处理,使得处理后...

如何防止你的 jar 被反编译?
本地化代码转换:牺牲一定的跨平台性,将代码转换为本地机器代码,降低反编译的难度,但可能影响代码的移植性。 代码混淆艺术:包括符号混淆、数据混淆、控制混淆和预防性混淆,它们是基本保护手段。符号混淆混淆方法和变量名,数据混淆则处理数据的存储和访问方式,控制混淆扰乱程序逻辑,预防性混淆则针对...

Java全系工程源码加密,防止反编译
ClassFinal是一款专为JAVA项目设计的安全加密工具,无需修改代码即可支持jar或war包加密,有效防止源码泄漏和字节码被反编译。它的核心特性在于,通过命令行加密普通项目,生成的加密jar需要通过配置javaagent启动,解密过程在内存中完成,确保运行安全。IDEA中启动加密jar也变得简单,只需在运行配置中添加相应的...

如何防止你的 jar 被反编译?
1. 隔离 Java 程序 将关键 Java Class 存储在服务器端,客户端通过访问服务接口获得服务,避免直接接触 Class 文件,从而阻止反编译。这种方法适用于服务器端应用,但不适合单机程序。2. Class 文件加密 对关键类进行加密,如注册码、序列号管理类,使用自定义 ClassLoader 进行解密和装载。虽然增加了...

怎么防止程序反编译
最基本的就是加壳。最好是VM壳,破解难度相对高许多;当然,“防君子不防小人”。

如何防止代码被反编译?
针对代码反编译,推荐使用CBS赛博锁,通过把安全容器内嵌到操作系统中,对容器内的应用和数据进行加锁,程序和数据在容器内运行,实现最后一米数据安全,防止核心数据被泄露,防止服务器终端中病毒,防止反编译,反破解。

有哪些防止反编译 Java 类库 jar 文件的办法
java本就是开源的,你加密感觉怪怪的。想防止反编译,最简单的方法就是你可以向Jar注入无效代码。比如建一个类,建一个没有意义的方法private class Invalid{ },然后输出为jar。用解压缩软件打开这个jar,以文本方式找到那个类的class,然后将那个方法名的一个字母删掉,然后更新入压缩文件中。用jd-...

如何防止程序员反编译?
这时候,防止反编译就成了必然!但前面也说过了,因为开放理念的原因,class是可以被反编译的,那现在有这样的需求之后,有哪些方式可以做到防止反编译呢?经过研究java源代码并进行了一些技术实现(结果发现,以前都有人想到过,所以在对应章节的时候,我会贴出一些写得比较细的文章,而我就简单阐述一下,也算偷个懒吧),我...

相似回答