当前位置: 代码网 > it编程>编程语言>Java > 使用ClassFinal实现SpringBoot项目jar包加密的操作指南

使用ClassFinal实现SpringBoot项目jar包加密的操作指南

2024年07月02日 Java 我要评论
前言在实际开发中,保护项目的安全性和保密性是至关重要的。针对于 spring boot 项目,如果不经过加密,其他人可以直接通过gui反编译轻而易举拿到源码,所以我们需要将 jar 包进行加密从而有效

前言

在实际开发中,保护项目的安全性和保密性是至关重要的。针对于 spring boot 项目,如果不经过加密,其他人可以直接通过gui反编译轻而易举拿到源码,所以我们需要将 jar 包进行加密从而有效地防止未经授权的访问和修改。

本文将介绍如何使用classfinalspring boot 项目中实现 jar 包加密。

什么是classfinal

classfinal是一个java字节码混淆和加密工具,可以将java类文件转换为不可读的形式,从而保护代码免受逆向工程的攻击。它提供了强大的加密算法,可以有效地保护您的应用程序免受非法访问。

项目地址:https://gitee.com/roseboy/classfinal

在这里插入图片描述

注意:虽然目前该项目在gitee上拥有1.6k的star,但已经暂停维护!
经小伙伴的反馈jdk17+springboot3.3.0 会有 startup failed, invalid password. 无法解密的问题,
经过博主测试 springboot3.2.0 + 确实存在这个问题,当然你是可以根据作者源码修改调整加解密方法来解决的

jdk17 + springboot3.3.0 出现 startup failed, invalid password.

在这里插入图片描述

博主测试使用了springboot3.1.0 + jdk17是完全支持的

以下是解密运行的截图

springboot 2.7.12 + jdk17

在这里插入图片描述

springboot 3.1.0 + jdk17

在这里插入图片描述

项目模块说明

  • classfinal-core: classfinal的核心模块,几乎所有加密的代码都在这里;
  • classfinal-fatjar: classfinal打包成独立运行的jar包;
  • classfinal-maven-plugin: classfinal加密的maven插件;

功能特性

  • 无需修改原项目代码,只要把编译好的jar/war包用本工具加密即可
  • 运行加密项目时,无需求修改 tomcat,spring 等源代码
  • 支持普通 jar 包、springboot jar 包以及普通 java web 项目编译的 war 包
  • 支持spring framework、swagger等需要在启动过程中扫描注解或生成字节码的框架
  • 支持maven插件,添加插件后在打包过程中自动加密
  • 支持加密web-inf/lib或boot-inf/lib下的依赖jar包
  • 支持绑定机器,项目加密后只能在特定机器运行
  • 支持加密springboot的配置文件

参数执行方式使用

首先下载jar包

对我们需要运行的项目jar包进行加密,下面是官方的使用样例:

java -jar classfinal-fatjar.jar \
-file yourproject.jar \
-libjars a.jar,b.jar \
-packages com.yourpackage,com.yourpackage2 \
-exclude com.yourpackage.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 :无需确认,不加此参数会提示确认以上信息

结果: 生成 yourproject-encrypted.jar,这个就是加密后的jar文件;加密后的文件不可直接执行,需要配置javaagent

注: 以上示例是直接用参数执行,也可以直接执行 java -jar classfinal-fatjar.jar按照步骤提示输入信息完成加密。

maven插件方式使用

在要加密的项目pom.xml中加入以下插件配置,目前最新版本是:1.2.1

<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>000000</password>
        <packages>com.yourpackage,com.yourpackage2</packages>
        <cfgfiles>application.yml</cfgfiles>
        <excludes>org.spring</excludes>
        <libjars>a.jar,b.jar</libjars>
    </configuration>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>classfinal</goal>
            </goals>
        </execution>
    </executions>
</plugin>

执行maven打包,在target目录下会发现多了一个 xxx-encrypted.jar的加密好的jar文件

在这里插入图片描述

验证加密的jar包

下载反编译工具jd-gui : 下载地址:http://java-decompiler.github.io

在这里插入图片描述

选择自己对应系统的版本下载即可;

小小的提示:博主之前遇到的问题

由于博主是macos系统,之前只有jdk8的时候运行正常,但当在电脑上同时安装了高版本的jdk,会出现jd-gui打不开的问题

问题分析

由于是专为macos系统定制的org.jd.gui.osxapp作为启动类,当我们同时安装高版本的jdk会导致osxapp依赖的com.apple.eawt.application缺失,导致启动失败,此时只需要把启动类换成默认的org.jd.gui.app即可正常启动

解决办法

  • 找到 jd-gui.app 右键 显示包内容
  • 进入contents目录,打开info.plist文件
  • 搜索找到org.jd.gui.osxapp 替换为 org.jd.gui.app

​​​​​​​下载完成运行jd-gui工具,将我们项目生成的 xxx-encrypted.jar 拖入工具中查看,这里以博主测试生成的toher-admin-encrypted.jar为例,如下图:

在这里插入图片描述

可以看到相关方法体内容均已经清空了

运行加密的jar包

加密后的项目需要设置javaagent来启动,项目在启动过程中解密class,完全内存解密,不留下任何解密后的文件。

解密功能已经自动加入到 xxx-encrypted.jar中,所以启动时-javaagent与-jar相同,不需要额外的jar包。

启动jar项目执行以下命令:

java -javaagent:yourpaoject-encrypted.jar='-pwd 0000000' \
-jar yourpaoject-encrypted.jar

//参数说明
// -pwd      加密项目的密码  
// -pwdname  环境变量中密码的名字

总结

使用classfinal工具可以轻松地保护spring boot项目的jar包免受未经授权的访问和修改。通过将classfinal集成到项目的构建过程中,我们可以在打包项目时自动对类文件进行加密,提高了应用程序的安全性

以上就是使用classfinal实现springboot项目jar包加密的操作指南的详细内容,更多关于classfinal jar包加密的资料请关注代码网其它相关文章!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com