基于jvmti与C++实现Class的加密解密 (二)

    上篇文章讲的是c++实现jvmti进行解密。本篇实现的c++实现class的加密。要注意的是class的加密和解密一定要是配套的,不然后果你懂得。在此本人要科普下class的小知识(因为自己遇到过类似的坑)。cafebabe这是个神奇的东西class的魔数,打开class的二进制文件会看到前4个就是这个咖啡的名字。本人公司的中间件事weblogic,用weblogic进行项目部署的时候它会先校验你class的魔数对不对,如果魔数加密了的话。那么很不幸的是程序直接保存,并且不会将改文件向上递归到父级的classloader进行解析。本人只进行过weblogic的试验,改正之后tomcat、jboss也可以运行。

    在我已知的范围内Tomcat、weblogic等都有重写classloader,下图就是weblogic进行class的魔数进行校验的方法。可以将这个类的方法干掉,还可以不进行加密。对没有错就是不进行加密。只不过是前几个字节不进行加密就可以跳过这个校验了。当Tomcat、weblogic不能解析class是就会向上找jdk里面自己的classlodaer进行解析。这就用到我们的jvmti进行解密了。然后将解析之后的字节码放到虚拟机中。

 

    在加密的时候没有进行魔数的加密,在解密的时候就没法用魔数判断该class是解密还是非加密。(要知道在解密的时候第一版我也是用魔数进行判断的 囧~~),所以我们class的前八个字节不加密就可以了。那么如何让agentlib区分哪些是加密的非加密的。在这个过程中考虑过按照名字路径进行区分,但是有的路径名会重复。

    换种思路,既然cafebabe可以进行加密和非加密的区别,那么我的名字哪。没错,我就是在加密的时候将我的名字插入到加密的class里。在解密的时候class里有我的名字就是加密的,否则就是非加密的。在解密的时候将我的名字从解密后的class字节码中剔除,就实现了agentlib自己区分哪些要解密。恩 就这么多了。


  1. Jvmtic++ 实现desclass加密解密

    这个四个文件是实现加密解密的demo,实现了单个文件的加密解密。可通过自己扩展循环调用来实现多个文件和jar包的加密解密。

    其中des.cpp文件实现加密解密。

    Des_encrypt2为加密方法。

    Des_decrypt3为解密方法。

    这两个方法在dllmain.cpp中的MyclassFileLoadHook方法中调用

    其中name为文件的名字例如:com/yang/test/test1

    以这种方式包名文件名存在。

    可以在这个方法中添加判断判断哪个包下的文件需要进行加密解密。

     

    Windows

             Windows下可以通过IDE创建dll项目可以自动生成 .dll文件。

    Myeclipse调用–agentlib:G”\test  调用g盘下的test.dll动态库。

    Dos窗口下 java –agent:G:\test class文件即可调用

     

     

    Linux

             linux下需要手动进行编译

  2. g++ -I/jdk1.6.0_45/include/ -I/jdk1.6.0_45/include/linux/ des.h  dll.h des.cpp dllmain.cpp   -fPIC -shared -o libtest.so
    里面的命令进行编译编译为libtest.so文件该文件为linux下需要引用的动态库。视系统而定可以放在 /usr/lib /lib64 我的虚拟机放的是 /lib64下面或添加LD_library_path

    下图为linux下测试调用

    Java –agentlib:test com.yang.test.test2

    其中test 为我们已经指定好的动态库路径下的动态库libtest.so

     



 




  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
众所周知,Java编译后的Jar包和Class文件,可以轻而易举的使用反编译工具(如JD-GUI)进行反编译,拿到源码。为了保护自己发布的Jar包和Class文件,采用的方式大多是混淆方式,这种方式对于Class文件的密是不彻底的,还是能够通过分析得出核心算法。本工具是采用jvmti方式对Class文件进行密,使用C++生成密和解密库,先用密库对Jar包进行密,将密后的Jar包及解密库文件发布出去,执行时候需要JVM引入解密库文件,解密后执行。c++的.dll文件和.so文件的破解难度是很大的,这就能有效的保护软件和代码的知识产权. 使用方法: 1.打开windows命令行(运行=>cmd=>回车),在命令行中 进入 EncryptJar目录 2.执行 java -jar encrypt.jar 3.输入h,然后回车,可以看到帮助菜单 4.输入3,然后按回车键,进入入jar文件功能 5.输入要密的jar文件的路径 6.提示输入秘钥(key)的时候,直接回车,不要输入任何字符(否则后面classhook将不可解密密后的jar包) 7.输入目标路径(密后的jar文件路径,此处要注意:jar文件名要保持相同,将密后的文件保存到不同的目录) 8.将密后的jar包,替换原来的没有密的jar包,与要发布的程序一起进行发布.(一般替换lib目录下对应的jar包即可) 9.密后的jar包运行方法: windows下: 拷贝libClassHook.dll文件到程序的根目录(通常为要执行的jar程序的根目录) 使用以下命令启动程序: java -agentlib:libClassHook -jar xxxxxxxxxxx.jar 则在运行过程中会自动进行解密操作(解密过程是运行过程中用c++的dll进行解密的,可以有效防止破解class文件) 如果执行过程报错,可将程序根目录添到环境变量path中去 Linux下: 拷贝libClassHook.so到程序的根目录(通常为要执行的jar程序的根目录) 使用以下命令启动程序: java -agentlib:ClassHook -jar xxxxxxxxxxx.jar (这里要删除掉lib,linux系统下会自动补全) 则在运行过程中会自动进行解密操作(解密过程是运行过程中用c++的dll进行解密的,可以有效防止破解class文件) 如果执行过程报错,可以在程序根目录下执行以下语句:export LD_LIBRARY_PATH=`pwd`:$LD_LIBRARY_PATH 或将libClassHook.so 拷贝到/usr/lib目录中去。 支持操作系统:密请在windows64位系统并安装了64位jdk环境下进行。 需要解密运行的程序支持LINUX(64位)和windows(64位)安装了JDK1.8以上的系统。 测试程序: (t_lib目录下的jar包为经过密的jar包) java -agentlib:libClassHook -jar test.jar
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值