Java Jar 包加密 -- XJar

彈琴不談情發表於2020-06-20

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,然後打包就可以了,其他操作方式和第一種類似

    注意:密碼最好採用命令列方式

<pluginRepositories>
  <pluginRepository>
    <id>jitpack.io</id>
    <url>https://jitpack.io</url>
  </pluginRepository>
</pluginRepositories>

       

 <plugin> <groupId>com.github.core-lib</groupId> <artifactId>xjar-maven-plugin</artifactId> <version>4.0.0</version> <executions> <execution> <goals> <goal>build</goal> </goals> <phase>install</phase> <configuration> <password>1233445</password> <includes>
                   <!----> <include>/com/xxx/xxx/**/*.class</include> </includes> <!-- 無需加密的資源路徑表示式 --> <excludes> <exclude>static/**</exclude> <exclude>META-INF/resources/**</exclude> </excludes> <!-- 源jar所在目錄 --> <sourceDir>path\</sourceDir> <!-- 源jar名稱 --> <sourceJar>xxx.jar</sourceJar> <!-- 目標jar存放目錄 --> <targetDir>path\test2</targetDir> <!-- 目標jar名稱 --> <targetJar>xxx-encrypted.jar</targetJar> </configuration> </execution> </executions> </plugin>

四、後記

  其實所有軟體,都可以被破解,只是破解過程是簡單還是複雜、以及破解成本的高低。

  最關鍵的還是自己軟體要更新迭代的快,這樣才能把模仿者遠遠甩在身後。

  轉發請註明出處!!!

相關文章