Java Class 加密工具 ClassFinal详解
作者:笑虾 发布时间:2023-02-10 14:58:48
Jar包加密工具 ClassFinal
介绍
ClassFinal 是一款 java class 文件安全加密工具,支持直接加密jar包或war包,无需修改任何项目代码,兼容spring-framework;可避免源码泄漏或字节码被反编译。
加密后,原始的class文件中方法体被清空,当class被classloader加载时,真正的方法体会被解密注入。
为兼容spring,swagger等扫描注解的框架,故而保留了方法参数、注解等信息;反编译者只能看到方法名和注解;
注意:为了保证项目在运行时的安全,启动jvm时请加参数: -XX:+DisableAttachMechanism 。
此参数的含义是禁用JVM的附加机制。在JVM中,有一个附加机制可以让外部进程通过Java Debug Wire Protocol(JDWP)协议附加到正在运行的Java进程上,从而获得进程的调试信息。这个机制在调试和诊断Java应用程序时非常有用。
然而,在某些情况下,禁用这个机制可以提高Java应用程序的安全性。例如,如果您希望限制外部进程对正在运行的Java进程的访问,或者想要确保Java进程不会被未经授权的用户附加和调试,您可以使用这个参数来禁用JVM的附加机制。当使用这个参数时,JVM将不再响应任何附加请求,从而防止外部进程通过JDWP协议附加到正在运行的Java进程上。
例:java -XX:+DisableAttachMechanism -jar MyApp.jar
环境依赖
JDK 1.8 +
使用说明
下载
点此下载
加密 命令行
执行以下命令
java -jar classfinal-fatjar.jar -file jerry.jar -libjars a.jar,b.jar -packages com.jerry1,com.jerry2 -exclude com.jerry.Main -pwd 123456 -Y
参数说明
-file 加密的jar/war完整路径
-packages 加密的包名(可为空,多个用","分割)
-libjars jar/war包lib下要加密jar文件名(可为空,多个用","分割)
-cfgfiles 需要加密的配置文件,一般是classes目录下的yml或properties文件(可为空,多个用","分割)
-exclude 排除的类名(可为空,多个用","分割)
-classpath 外部依赖的jar目录,例如/tomcat/lib(可为空,多个用","分割)
-pwd 加密密码,如果是#号,则使用无密码模式加密
-code 机器码,在绑定的机器生成,加密后只可在此机器上运行
-Y 无需确认,不加此参数会提示确认以上信息
结果: 生成加密后的jar文件 jerry-encrypted.jar
。执行时需带 javaagent
参数。
注: 也可以直接执行 java -jar classfinal-fatjar.jar 以交互式操作。
示例
我的jar包:jerry.jar
,密码123456
java -jar classfinal-fatjar-1.2.1.jar -file jerry.jar -packages com.jerry -pwd 123456 -Y
=========================================================
= =
= Java Class Encryption Tool v1.2.1 by Mr.K =
= =
=========================================================
加密信息如下:
-------------------------
1. jar/war路径: jerry.jar
2. lib下的jar:
3. 包名前缀: com.jerry
4. 排除的类名:
5. 加密配置文件:
6. ClassPath:
7. 密码: 123456
8. 机器码:
-------------------------
处理中...
加密完成,请牢记密码!
==>jerry-encrypted.jar
maven插件方式
在要加密的项目pom.xml中加入以下插件配置,目前最新版本是:1.2.1。
<build>
<finalName>${project.artifactId}</finalName>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<plugin>
<!-- https://gitee.com/roseboy/classfinal -->
<groupId>net.roseboy</groupId>
<artifactId>classfinal-maven-plugin</artifactId>
<version>1.2.1</version>
<configuration>
<!-- 加密打包之后pom.xml会被删除,不用担心在jar包里找到此密码-->
<password>jerry</password>
<!-- 需要加密的包。多个以逗号,分割 -->
<packages>com.classfinal</packages>
<!-- 需要加密的配置文件。多个以逗号,分割 -->
<cfgfiles>bootstrap.yml,application.yml</cfgfiles>
<!-- 不想要加密的jar包。多个以逗号,分割 -->
<excludes>org.spring</excludes>
<!-- 加密依赖的第三方jar包。多个以逗号,分割 -->
<libjars>jerry-common-core-0.0.1.jar,jerry-common-redis-0.0.1.jar</libjars>
</configuration>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>classFinal</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
运行mvn package
时会在target
下自动加密生成yourpaoject-encrypted.jar
。
maven 插件的参数名称与直接运行的参数相同,请参考上节的参数说明。
无密码模式
加密时
-pwd
参数设为#
,启动时可不用输入密码;如果是war包,启动时指定参数
-nopwd
,跳过输密码过程。
机器绑定
机器绑定只允许加密的项目在特定的机器上运行;
加密时用 -code
指定机器码。机器绑定可同时支持机器码
+密码
的方式加密。
在需要绑定的机器上执行以下命令,生成机器码
java -jar classfinal-fatjar.jar -C
启动加密后的jar
加密后的项目需要设置 javaagent
来启动,项目在启动过程中解密class,完全内存解密,不留下任何解密后的文件。
解密功能已经自动加入到 yourpaoject-encrypted.jar
中,所以启动时 -javaagent
与 -jar
相同,不需要额外的jar包。
密码读取顺序:参数获取
>> 环境变量获取
>> 密码文件获取
>> 控制台输入
>> GUI输入
>> 退出
启动参数给密码
启动jar项目执行以下命令:注意:如果是win系统 "-pwd 0000000"
这里要用双引号。
java -javaagent:jerry-encrypted.jar="-pwd 0000000" -jar jerry-encrypted.jar
//参数说明
// -pwd 加密项目的密码
// -pwdname 环境变量中密码的名字
不加密码参数直接启动
1. 密码文件获取
java -javaagent:yourpaoject-encrypted.jar -jar yourpaoject-encrypted.jar
不加 pwd
参数直接启动,优先从密码文件
读取。
在同级目录下的classfinal.txt
或jerry-encrypted.classfinal.txt
中写入密码。
直接给密码:classfinal.txt
123456
参数化配置启动后删除:classfinal.txt
--pwd 123456 --del yes
这里的del
只要不给false
或no
都会删除。
项目读取到密码后会清空此文件。
2. 交互输入
没有找到 密码文件
就会进入交互输入模式:先控制台输入
还是没给密码就会进入 GUI输入
模式,都不给密码,就报错退出了。
控制台输入
GUI输入
参考资料
Gitee: https://gitee.com/roseboy/classfinal
来源:https://blog.csdn.net/jx520/article/details/129440468


猜你喜欢
- using System; using System.Collections.Generic; using
- 话不多说,请看代码:import java.io.*; import jxl.*; import jxl.write.*; //用java将
- C# Linq获取两个List或数组的差集交集List<int> list1 = newList<int>();li
- 效果:一个手指实现(所有手势事件)和(部分事件的);A. 所有手势activity_main.xml<TextView android
- 邮件绑定功能【需求】1、 用户注册时,输入邮箱2、 通过Javamail技术,向用户邮箱发送一封祝贺邮件1、javamail发送邮件1.1、
- 正则表达式 是一种匹配输入文本的模式。.Net 框架提供了允许这种匹配的正则表达式引擎。模式由一个或多个字符、运算符和结构组成。接下来通过本
- 事务处理基本原理 事务是将一系列操作作为一个单元执行,要么成功,要么失败,回滚到
- 什么是二叉堆二叉堆就是完全二叉树,或者是靠近完全二叉树结构的二叉树。在二叉树建树时采取前序建树就是建立的完全二叉树。也就是二叉堆。所以二叉堆
- 本文为大家分享了WebSocket实现Web聊天室的具体代码,供大家参考,具体内容如下一.客户端JS代码如下:/* * 这部分
- 本文实例讲述了Android开发之SeekBar基本使用及各种美观样式。分享给大家供大家参考,具体如下:改变控件透明度只需通过 .setAl
- java8 Stream大数据量List分批处理//按每3个一组分割private static final Integer MAX_NUM
- 1.配置自定义共享线程池(Spring线程池)@Configuration@EnableAsyncpublic class ThreadPo
- 我们在实际开发中,有的时候需要储存或者备份比较复杂的数据。这些数据的特点是,内容多、结构大,比如短信备份等。我们知道SharedPrefer
- 只需要在控件TextBox的keypress事件中写入如下代码即可满足要求:代码如下:if (e.KeyChar == '.'
- Java内存区域与内存溢出异常概述对于 C 和 C++程序开发的开发人员来说,在内存管理领域,程序员对内存拥有绝对的使用权,但是也要主要到正
- 本文主要讲解MVP开发模式以及具体实例。一、简介MVP(Model View Presenter)模式是著名的MVC(Model View
- 1. 获取绝对文件路径System.IO.Path.GetFullPath(string path)string fileName = &q
- 前言Spring是什么?它是一个应用程序框架,为应用程序的开发提供强大的支持,例如对事务处理和持久化的支持等;它也是一个bean容器,管理b
- 一、前言环境:jdk 1.8,SpringCloud Greenwich.SR2。如题,springcloud config-client启
- 上标是指比同一行中其他文字稍高的文字,而下标是指比同一行中其他文字稍低的文字。在生活中,我们常见的平方米、立方米等符号以及化学中的各种元素符