Java Class 加密工具 ClassFinal詳解
Jar包加密工具 ClassFinal
介紹
- ClassFinal 是一款 java class 文件安全加密工具,支持直接加密jar包或war包,無需修改任何項目代碼,兼容spring-framework;可避免源碼泄漏或字節(jié)碼被反編譯。
- 加密后,原始的class文件中方法體被清空,當(dāng)class被classloader加載時,真正的方法體會被解密注入。
- 為兼容spring,swagger等掃描注解的框架,故而保留了方法參數(shù)、注解等信息;反編譯者只能看到方法名和注解;
- 注意:為了保證項目在運行時的安全,啟動jvm時請加參數(shù): -XX:+DisableAttachMechanism 。
此參數(shù)的含義是禁用JVM的附加機制。在JVM中,有一個附加機制可以讓外部進程通過Java Debug Wire Protocol(JDWP)協(xié)議附加到正在運行的Java進程上,從而獲得進程的調(diào)試信息。這個機制在調(diào)試和診斷Java應(yīng)用程序時非常有用。
然而,在某些情況下,禁用這個機制可以提高Java應(yīng)用程序的安全性。例如,如果您希望限制外部進程對正在運行的Java進程的訪問,或者想要確保Java進程不會被未經(jīng)授權(quán)的用戶附加和調(diào)試,您可以使用這個參數(shù)來禁用JVM的附加機制。當(dāng)使用這個參數(shù)時,JVM將不再響應(yīng)任何附加請求,從而防止外部進程通過JDWP協(xié)議附加到正在運行的Java進程上。
例:java -XX:+DisableAttachMechanism -jar MyApp.jar
環(huán)境依賴
JDK 1.8 +
使用說明
下載
加密 命令行
執(zhí)行以下命令
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
參數(shù)說明
-file 加密的jar/war完整路徑
-packages 加密的包名(可為空,多個用","分割)
-libjars jar/war包lib下要加密jar文件名(可為空,多個用","分割)
-cfgfiles 需要加密的配置文件,一般是classes目錄下的yml或properties文件(可為空,多個用","分割)
-exclude 排除的類名(可為空,多個用","分割)
-classpath 外部依賴的jar目錄,例如/tomcat/lib(可為空,多個用","分割)
-pwd 加密密碼,如果是#號,則使用無密碼模式加密
-code 機器碼,在綁定的機器生成,加密后只可在此機器上運行
-Y 無需確認(rèn),不加此參數(shù)會提示確認(rèn)以上信息
結(jié)果: 生成加密后的jar文件 jerry-encrypted.jar。執(zhí)行時需帶 javaagent 參數(shù)。
注: 也可以直接執(zhí)行 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會被刪除,不用擔(dān)心在jar包里找到此密碼-->
<password>jerry</password>
<!-- 需要加密的包。多個以逗號,分割 -->
<packages>com.classfinal</packages>
<!-- 需要加密的配置文件。多個以逗號,分割 -->
<cfgfiles>bootstrap.yml,application.yml</cfgfiles>
<!-- 不想要加密的jar包。多個以逗號,分割 -->
<excludes>org.spring</excludes>
<!-- 加密依賴的第三方j(luò)ar包。多個以逗號,分割 -->
<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 插件的參數(shù)名稱與直接運行的參數(shù)相同,請參考上節(jié)的參數(shù)說明。
無密碼模式
- 加密時
-pwd參數(shù)設(shè)為#,啟動時可不用輸入密碼; - 如果是war包,啟動時指定參數(shù)
-nopwd,跳過輸密碼過程。
機器綁定
機器綁定只允許加密的項目在特定的機器上運行;
加密時用 -code 指定機器碼。機器綁定可同時支持機器碼+密碼的方式加密。
在需要綁定的機器上執(zhí)行以下命令,生成機器碼
java -jar classfinal-fatjar.jar -C
啟動加密后的jar
加密后的項目需要設(shè)置 javaagent來啟動,項目在啟動過程中解密class,完全內(nèi)存解密,不留下任何解密后的文件。
解密功能已經(jīng)自動加入到 yourpaoject-encrypted.jar 中,所以啟動時 -javaagent 與 -jar 相同,不需要額外的jar包。
密碼讀取順序:參數(shù)獲取 >> 環(huán)境變量獲取 >> 密碼文件獲取 >> 控制臺輸入 >> GUI輸入 >> 退出
啟動參數(shù)給密碼
啟動jar項目執(zhí)行以下命令:注意:如果是win系統(tǒng) "-pwd 0000000" 這里要用雙引號。
java -javaagent:jerry-encrypted.jar="-pwd 0000000" -jar jerry-encrypted.jar //參數(shù)說明 // -pwd 加密項目的密碼 // -pwdname 環(huán)境變量中密碼的名字
不加密碼參數(shù)直接啟動
1. 密碼文件獲取
java -javaagent:yourpaoject-encrypted.jar -jar yourpaoject-encrypted.jar
不加 pwd 參數(shù)直接啟動,優(yōu)先從密碼文件讀取。
在同級目錄下的classfinal.txt或jerry-encrypted.classfinal.txt中寫入密碼。
直接給密碼:classfinal.txt
123456
參數(shù)化配置啟動后刪除:classfinal.txt
--pwd 123456 --del yes
這里的del只要不給false或no都會刪除。
項目讀取到密碼后會清空此文件。
2. 交互輸入
沒有找到 密碼文件 就會進入交互輸入模式:先控制臺輸入還是沒給密碼就會進入 GUI輸入模式,都不給密碼,就報錯退出了。
控制臺輸入

GUI輸入

參考資料
Gitee: https://gitee.com/roseboy/classfinal
到此這篇關(guān)于Java Class 加密工具 ClassFinal的文章就介紹到這了,更多相關(guān)java加密class內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SpringBoot中使用Cookie實現(xiàn)記住登錄的示例代碼
這篇文章主要介紹了SpringBoot中使用Cookie實現(xiàn)記住登錄的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
SpringBoot整合ZXing實現(xiàn)二維碼和條形碼的創(chuàng)建
如今我們越來越多的東西需要用到二維碼或者條形碼,商品的條形碼,付款的二維碼等等,所以本文小編給大家介紹了SpringBoot整合ZXing實現(xiàn)二維碼和條形碼的創(chuàng)建,文章通過代碼示例給大家介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12
Java微信公眾平臺開發(fā)(4) 回復(fù)消息的分類及實體的創(chuàng)建
這篇文章主要為大家詳細(xì)介紹了Java微信公眾平臺開發(fā)第四步,回復(fù)消息的分類及實體的創(chuàng)建,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04
springMVC中@RequestParam和@RequestPart的區(qū)別
本文主要介紹了springMVC中@RequestParam和@RequestPart的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-06-06

