Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

编译

简单就是把代码跑一哈,然后我们的代码 .java文件 就被编译成了 .class 文件

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

反编译

就是针对编译生成的 jar/war 包 里面的 .class 文件 逆向还原回来,可以看到你的代码写的啥。

比较常用的反编译工具 JD-GUI ,直接把编译好的jar丢进去,大部分都能反编译看到源码:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

那如果不想给别人反编译看自己写的代码呢?

怎么做?

混淆

该篇玩的代码混淆 ,是其中一种手段。

我给你看,但你反编译看到的不是真正的代码。

先看一张效果示例图 :

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

开搞

正文

先看一下我们混淆一个项目代码,要做啥?

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

一共就两步

推荐一个开源免费的 Spring Boot 最全教程:

https://github.com/javastacks/spring-boot-best-practice

第一步, 在项目路径下,新增一份文件 proguard.cfg :

proguard.cfg

#指定Java的版本
-target 1.8
#proguard会对代码进行优化压缩,他会删除从未使用的类或者类成员变量等
-dontshrink
#是否关闭字节码级别的优化,如果不开启则设置如下配置
-dontoptimize
#混淆时不生成大小写混合的类名,默认是可以大小写混合
-dontusemixedcaseclassnames
# 对于类成员的命名的混淆采取唯一策略
-useuniqueclassmembernames
#混淆时不生成大小写混合的类名,默认是可以大小写混合
-dontusemixedcaseclassnames
#混淆类名之后,对使用Class.forName('className')之类的地方进行相应替代
-adaptclassstrings

#对异常、注解信息予以保留
-keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,*Annotation*,EnclosingMethod
# 此选项将保存接口中的所有原始名称(不混淆)-->
-keepnames interface ** { *; }
# 此选项将保存所有软件包中的所有原始接口文件(不进行混淆)
#-keep interface * extends * { *; }
#保留参数名,因为控制器,或者Mybatis等接口的参数如果混淆会导致无法接受参数,xml文件找不到参数
-keepparameternames
# 保留枚举成员及方法
-keepclassmembers enum * { *; }
# 不混淆所有类,保存原始定义的注释-
-keepclassmembers class * {
                        @org.springframework.context.annotation.Bean *;
                        @org.springframework.beans.factory.annotation.Autowired *;
                        @org.springframework.beans.factory.annotation.Value *;
                        @org.springframework.stereotype.Service *;
                        @org.springframework.stereotype.Component *;
                        }

#忽略warn消息
-ignorewarnings
#忽略note消息
-dontnote
#打印配置信息
-printconfiguration
-keep public class com.example.myproguarddemo.MyproguarddemoApplication {
        public static void main(java.lang.String[]);
    }

注意点:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

其余的看注释,可以配置哪些类不参与混淆,哪些枚举保留,哪些方法名不混淆等等。

第二步,在pom文件上 加入proguard 混淆插件 :

build标签里面改动加入一下配置:

<build>
    <plugins>
        <plugin>
            <groupId>com.github.wvengen</groupId>
            <artifactId>proguard-maven-plugin</artifactId>
            <version>2.6.0</version>
            <executions>
                <!-- 以下配置说明执行mvn的package命令时候,会执行proguard-->
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>proguard</goal>
                    </goals>
                </execution>
            </executions>
            <configuration>
                <!-- 就是输入Jar的名称,我们要知道,代码混淆其实是将一个原始的jar,生成一个混淆后的jar,那么就会有输入输出。 -->
                <injar>${project.build.finalName}.jar</injar>
                <!-- 输出jar名称,输入输出jar同名的时候就是覆盖,也是比较常用的配置。 -->
                <outjar>${project.build.finalName}.jar</outjar>
                <!-- 是否混淆 默认是true -->
                <obfuscate>true</obfuscate>
                <!-- 配置一个文件,通常叫做proguard.cfg,该文件主要是配置options选项,也就是说使用proguard.cfg那么options下的所有内容都可以移到proguard.cfg中 -->
                <proguardInclude>${project.basedir}/proguard.cfg</proguardInclude>
                <!-- 额外的jar包,通常是项目编译所需要的jar -->
                <libs>
                    <lib>${java.home}/lib/rt.jar</lib>
                    <lib>${java.home}/lib/jce.jar</lib>
                    <lib>${java.home}/lib/jsse.jar</lib>
                </libs>
                <!-- 对输入jar进行过滤比如,如下配置就是对META-INFO文件不处理。 -->
                <inLibsFilter>!META-INF/**,!META-INF/versions/9/**.class</inLibsFilter>
                <!-- 这是输出路径配置,但是要注意这个路径必须要包括injar标签填写的jar -->
                <outputDirectory>${project.basedir}/target</outputDirectory>
                <!--这里特别重要,此处主要是配置混淆的一些细节选项,比如哪些类不需要混淆,哪些需要混淆-->
                <options>
                    <!-- 可以在此处写option标签配置,不过我上面使用了proguardInclude,故而我更喜欢在proguard.cfg中配置 -->
                </options>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
            <executions>
                <execution>
                    <goals>
                        <goal>repackage</goal>
                    </goals>
                    <configuration>
                        <mainClass>com.example.myproguarddemo.MyproguarddemoApplication</mainClass>
                    </configuration>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

注意点:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

然后可以看到:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

然后点击package,正常执行编译打包流程就可以 :

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

然后可以看到jar的生成:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

看看效果:

Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了!

好了,该篇就到这。

本文链接:https://blog.csdn.net/qq_35387940/article/details/127426354

近期热文推荐:

1.1,000+ 道 Java面试题及答案整理(2022最新版)

2.劲爆!Java 协程要来了。。。

3.Spring Boot 2.x 教程,太全了!

4.别再写满屏的爆爆爆炸类了,试试装饰器模式,这才是优雅的方式!!

5.《Java开发手册(嵩山版)》最新发布,速速下载!

觉得不错,别忘了随手点赞+转发哦!

原文链接:https://www.cnblogs.com/javastack/p/17354609.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Spring Boot 项目代码混淆,实战来了,再也不用担心代码泄露了! - Python技术站

(0)
上一篇 2023年4月27日
下一篇 2023年4月27日

相关文章

  • Java状态设计模式实现对象状态转换的优雅方式

    Java状态设计模式是一种处理对象状态转换的优雅方式。在这种方法中,对象的状态转换完全是由状态本身以及状态之间的转换规则驱动的,这使得代码更为清晰、易于维护和扩展。 以下是实现对象状态转换的完整攻略: 1. 定义状态和状态转换规则 首先,需要定义状态和状态转换的规则,然后将它们封装成一个状态机对象。状态机应该具有进入某个状态的方法,以及从一个状态到另一个状态…

    Java 2023年5月26日
    00
  • 详解Java的线程状态

    Java中的线程可以处于不同的状态,包括NEW、RUNNABLE、BLOCKED、WAITING、TIMED_WAITING和TERMINATED。了解这些状态及其转换对于优化并发程序和解决并发问题非常重要。以下是详解Java的线程状态的完整攻略: 线程的状态 NEW:创建一个线程对象,但是还没有调用start方法时,线程对象的状态是NEW。 RUNNABL…

    Java 2023年5月18日
    00
  • 浅谈MyBatis 如何执行一条 SQL语句

    MyBatis 是一个优秀的持久化框架,其底层也是通过 JDBC 实现对数据库的操作。下面,我们就来详细讲解一下 MyBatis 如何执行一条 SQL 语句的完整攻略。 1. 读取 XML 配置文件 首先,MyBatis 会读取类路径下的 mybatis-config.xml(或者其他指定的配置文件)文件,该文件中包含了 MyBatis 的全局配置信息,其中…

    Java 2023年6月1日
    00
  • tomcat logs 目录下各日志文件的解析(小结)

    以下是“tomcat logs 目录下各日志文件的解析(小结)”的完整攻略: 1. tomcat logs 目录下各日志文件介绍 在Tomcat的logs目录下,包含了许多日志文件,每个文件都具有不同的作用,下面是各日志文件的介绍: 1.1 catalina.out catalina.out是Tomcat在启动时会自动生成的一个日志文件,它用于记录Tomca…

    Java 2023年5月19日
    00
  • 类似Object监视器方法的Condition接口(详解)

    下面我会详细讲解“类似Object监视器方法的Condition接口(详解)”的完整攻略。 Background 在Java中,有时我们需要等待一些特定条件的发生,才能继续执行接下来的操作。此时,我们可以使用Object的监视器方法,或者使用JDK1.5出现的Lock机制,但是它们都存在一些问题,比如在多线程环境下容易出现死锁等问题。为解决这些问题,Java…

    Java 2023年5月26日
    00
  • GsonFormat快速生成JSon实体类的实现

    下面是详细的攻略: 一、GsonFormat是什么 GsonFormat是用于快速生成Java类对应的JSON格式字符串的工具,实现了将JSON字符串转换成Java类的功能。 它是一个Intellij IDEA的插件,需要使用者在IDEA的插件市场进行安装。 二、GsonFormat的安装及使用方法 安装GsonFormat 1.在Intellij IDEA…

    Java 2023年5月26日
    00
  • Spring Boot如何实现定时任务的动态增删启停详解

    下面我会详细讲解“Spring Boot如何实现定时任务的动态增删启停详解”的完整攻略。 什么是定时任务? 定时任务(Scheduled Task)是指在指定的时间点或时间间隔内自动执行某个操作的任务。在很多场景下,我们经常需要定时执行某些操作,例如定时清理临时数据、定时发送邮件等。 Spring Boot如何实现定时任务 Spring Boot 提供了标准…

    Java 2023年5月19日
    00
  • Java8实现FTP及SFTP文件上传下载

    下面是关于“Java8实现FTP及SFTP文件上传下载”的完整攻略。 一、FTP文件上传下载 1.1 准备工作 在开始前,需要引入以下的Maven依赖: <dependency> <groupId>commons-net</groupId> <artifactId>commons-net</artifac…

    Java 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部