Java Jar 包加密
一、缘由
Java的 Jar包中的.class文件可以通过反汇编得到源码。这样一款应用的安全性就很难得到保证,别人只要得到你的应用,不需花费什么力气,就可以得到源码。
这时候就需要对jar进行加密处理。
二、技术&工具
XJar
GitHub:https://github.com/core-lib/xjar
码云:https://gitee.com/core-lib/xjar?_from=gitee_search
maven集成 XJar
GitHub:https://github.com/core-lib/xjar-maven-plugin
码云:https://gitee.com/core-lib/xjar-maven-plugin?_from=gitee_search
xjar-agent-hibernate
GitHub:https://github.com/core-lib/xjar-agent-hibernate
码云:https://gitee.com/core-lib/xjar-agent-hibernate?_from=gitee_search
go语言、maven、eclipse
文档可以到github、码云上去了解,这里只描述使用过程,亲测可用!
三、实现过程
这里使用的maven版本是:apache-maven-3.6.3,低版本的没测试过
1、XJar
1-1.在github或码云上下载该项目,导入eclipse,然后新建一个main类,填入参数,直接运行得到一个xjar.go 和 加密后的jar包【xx-encrypted.jar】。
注意:这种直接在项目中跑mian,不提倡,会导致jar包中包含这段代码,导致密码泄露,所以要通过命令行的方式来执行这段代码。
1-2.这时候可以用反编译软件 jb-gui 打开jar看看加密的效果,这时候反编译软件已经看不到.class文件的源码了
1-3.加密后的jar包,不能直接用原来的java 命令来执行,需要用到同时生成的xjar.go文件,执行命令 go build xjar.go
这里要等待一小会,等待编译出目标文件xjar.exe
1-4. 最后执行命令,xjar java -jar /path/to/encrypted.jar,即可运行加密后的jar包
注意:Spring Boot + JPA(Hibernate) 启动会报错
1-5:没有采用 Spring Boot + JPA(Hibernate) 技术的可以略过以下步骤。
a、到码云、GitHub上下载 xjar-agent-hibernate 项目
b、导入eclipse 打包出jar包
c、然后执行命令 xjar java -javaagent:xjar-agent-hibernate-v1.0.0.jar -jar path\wx-encrypted.jar,即可正常运行
2、maven集成 XJar
第二种方式就比较简单了,直接在项目中引入xjar-maven-plugin,然后打包就可以了,其他操作方式和第一种类似
注意:密码最好采用命令行方式
com.github.core-lib xjar-maven-plugin 4.0.0 build install 1233445
/com/xxx/xxx/**/*.class static/** META-INF/resources/** path\ xxx.jar path\test2 xxx-encrypted.jar
四、后记
其实所有软件,都可以被破解,只是破解过程是简单还是复杂、以及破解成本的高低。
最关键的还是自己软件要更新迭代的快,这样才能把模仿者远远甩在身后。
转发请注明出处!!!