- 1、本文档共10页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
深入Java字节码加密
问:? 如果我把我的class文件 HYPERLINK /keywords/encryption.html \t _blank 加密,在运行时用指定的类加载器(class loader)装入并解密它,这样子能防止被反编译吗?? 答:防止 HYPERLINK /keywords/java.html \t _blank JAVA字节码反编译这个问题在java语言雏形期就有了,尽管市面上存在一些反编译的工具可以利用,但是JAVA程序员还是不断的努力寻找新的更有效的方法来保护他们的智慧结晶。在此,我将详细给大家解释这一直来在论坛上有争议的话题。出处:/article/434.html
? Class文件能被很轻松的重构生成JAVA源文件与最初JAVA字节码的 HYPERLINK /keywords/photoshop_e.html \t _blank 设计目的和商业交易有紧密地联系。另外,JAVA字节码被设计成简洁、平台独立性、网络灵活性,并且易于被字节码解释器和JIT (just-in-time)/HotSpot 编译器所分析。可以清楚地了解程序员的目的, Class文件要比JAVA源文件更易于分析。如果不能阻止被反编译的话,至少可以通过一些方法来增加它的困难性。例如: 在一个分步编译里,你可以打乱Class文件的数据以使其难读或者难以被反编译成正确的JAVA源文件,前者可以采用极端函数重载,后者用操作控制流建立控制结构使其难以恢复正常次序。有更多成功的商业困惑者采用这些或其他的技术来保护自己的代码。
不幸的是,哪种方法都必须改变JVM运行的代码,并且许多用户害怕这种转化会给他们的程序带来新的Bug。而且,方法和字段重命名会调用反射从而使程序停止工作,改变类和包的名字会破坏其他的JAVA APIS(JNDI, URL providers, etc),除了改变名字,如果字节码偏移量和源代码行数之间的关系改变了,在恢复这有异常的堆栈将很困难。? 于是就有了一些打乱JAVA源代码的选项,但是这将从本质上导致一系列问题的产生。
? 加密而不打乱?? 或许上述可能会使你问,假如我把字节码加密而不是处理字节码,并且JVM运行时自动将它解密并装入类加载器,然后JVM运行解密后的字节码文件,这样就不会被反编译了对吗??考虑到你是第一个提出这种想法的并且它又能正常运行,我表示遗憾和不幸,这种想法是错误的。
? 下面是一个简单的类编码器:??? 为了阐明这种思想,我采用了一个实例和一个很通用的类加载器来运行它,该程序包括两个类:
?public class Main{??? public static void main (final String [] args)??? {?? ??????? System.out.println (secret result = + MySecretClass.mySecretAlgorithm ());??? }
} // End of class
package my.secret.code;
import java.util.Random;
public class MySecretClass
{??? /**???? * Guess what, the secret algorithm just uses a random number generator... ???? */??? public static int mySecretAlgorithm ()??? {??????? return (int) s_random.nextInt ();??? }
??? private static final Random s_random = new Random (System.currentTimeMillis ());
} // End of class
? 我想通过 HYPERLINK /keywords/encryption.html \t _blank 加密相关的class文件并在运行期解密来隐藏my.secret.code.MySecretClass的执行。用下面这个工具可以达到 HYPERLINK /key/words/photoshop6.html \t _blank 效果(你可以到这里下载Resources):
public class EncryptedClassLoader extends URLClassLoader{??? ??? public static void main (final String [] args)??????? throws Exception??? {??????? ?
文档评论(0)