springboot 打包方式总结+proguard混淆+xjar加密

springboot 静态资源配置

war的使用习惯总感觉网页在jar包里非常不方便 以前总是用 下面的方式运行。

#以前总是通过这种方式将jar包和网页资源统统jar包外加载,总感觉不优雅。
java -jar -Dloader.path=lib,resource xxx.jar

利用spring得配置方式设置,在ide中的时候就把他注释掉,部署的时候打开

spring:
  #resources:
    #static-locations: file:./public/
分类打包lib和配置
<!--将resource中的页面内容过滤掉-->
<resource>
     <directory>src/main/resources</directory>
      <excludes>
          <exclude>public/**</exclude>
      </excludes>
      <filtering>false</filtering>
  </resource>
<!--将第三方依赖的jar,过滤到springboot打的jar之外-->
<plugin>
    <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-maven-plugin</artifactId>
    <configuration>
         <layout>ZIP</layout>
        <includes>
            <include>
                <groupId>nothing</groupId>
                <artifactId>nothing</artifactId>
            </include>
        </includes>
     </configuration>
     <executions>
         <execution>
             <goals>
                 <goal>repackage</goal>
             </goals>
         </execution>
     </executions>
  </plugin>

<!--拷贝第三方依赖文件到指定目录,自己手动挑这些jar包可不现实。-->
 <plugin>
     <groupId>org.apache.maven.plugins</groupId>
     <artifactId>maven-dependency-plugin</artifactId>
     <executions>
         <execution>
             <id>copy-dependencies</id>
             <phase>package</phase>
             <goals>
                 <goal>copy-dependencies</goal>
             </goals>
             <configuration>
                 <outputDirectory>target/lib</outputDirectory>
                 <excludeTransitive>false</excludeTransitive>
                 <stripVersion>false</stripVersion>
                 <includeScope>runtime</includeScope>
             </configuration>
         </execution>
     </executions>
 </plugin>

通过以上几步,生成的jar会相当小,里面只有自己写的代码和配置文件。而所有的第三方的jar都在target/lib文件夹中。

progurd jar包混淆
<dependency>
     <groupId>net.sf.proguard</groupId>
      <artifactId>proguard-base</artifactId>
      <version>6.0.2</version>
  </dependency>
<plugin>
  <groupId>com.github.wvengen</groupId>
  <artifactId>proguard-maven-plugin</artifactId>
  <executions>
      <execution>
          <phase>package</phase>
          <goals><goal>proguard</goal></goals>
      </execution>
  </executions>
  <configuration>
      <proguardVersion>6.0.2</proguardVersion>
      <injar>${project.build.finalName}.jar</injar>
      <outjar>${project.build.finalName}.jar</outjar>
      <obfuscate>true</obfuscate>
      <options>
          <!-- 不做收缩(删除注释、未被引用代码) -->
          <option>-dontshrink</option>
          <!-- 不做优化(变更代码实现逻辑) -->
          <option>-dontoptimize</option>
          <!-- 不路过非公用类文件及成员 -->
          <option>-dontskipnonpubliclibraryclasses</option>
          <option>-dontskipnonpubliclibraryclassmembers</option>
          <!-- 优化时允许访问并修改有修饰符的类和类的成员 -->
          <option>-allowaccessmodification</option>
          <!-- 确定统一的混淆类的成员名称来增加混淆 -->
          <option>-useuniqueclassmembernames</option>
          <!-- 不混淆所有包名,本人测试混淆后WEB项目问题实在太多,毕竟Spring配置中有
          大量固定写法的包名 -->
          <option>-keeppackagenames</option>
          <option>-adaptclassstrings</option>
          <!-- 不混淆所有特殊的类 -->
          <option>-keepattributes
              Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,LocalVariable*Table,*Annotation*,Synthetic,EnclosingMethod</option>
          <option>-keepparameternames</option>
          <option>-dontusemixedcaseclassnames</option>
          <option>-dontskipnonpubliclibraryclasses</option>
          <option>-verbose</option>
          <option>-ignorewarnings</option>
          <option>-keepclassmembers class * {
              @org.springframework.beans.factory.annotation.Autowired *;
              @org.springframework.beans.factory.annotation.Value *;
              }
          </option>
          <!-- 不混淆main方法 -->
          <option>-keep class com.bh.sigApp { *; }</option>

          <!-- 不混淆所有的set/get方法 -->
          <option>-keepclassmembers public class * {void set*(***);***
              get*();}</option>
          <!-- 不混淆包中的所有类以及类的属性及方法,实体包,混淆了会导致ORM框架及前端无法识别 -->

          <!-- 不对包类的类名进行混淆,但对类中的属性和方法混淆 -->
          <option>-keep class com.bh.controller.** </option>
          <option>-keep class com.bh.service.** </option>
          <!-- 不混淆包下的所有类名,且类中的方法也不混淆 -->
          <option>-keep class com.bh.pojo.** {*;}</option>
          <option>-keep class
              com.bh.dto.** {*;}</option>

          <option>-keep class com.bh.config.**{*;}</option>
          <option>-keep class com.bh.dao.** {*;}</option>

      </options>
      <libs>
          <!-- Include main JAVA library required.-->
          <lib>${java.home}/lib/rt.jar</lib>
          <lib>${java.home}/lib/jce.jar</lib>
      </libs>
  </configuration>
  <dependencies>
      <dependency>
          <groupId>net.sf.proguard</groupId>
          <artifactId>proguard-base</artifactId>
          <version>6.0.2</version>
          <scope>runtime</scope>
      </dependency>
  </dependencies>
</plugin>

在这里插入图片描述
注释都没有了,工具类进行了完全混淆,其他类使用了部分混淆
在这里插入图片描述

xjar对于生成的jar 加密
<dependency>
     <groupId>com.github.core-lib</groupId>
     <artifactId>xjar</artifactId>
     <version>v2.0.6</version>
 </dependency>

在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,那我来为你介绍一下 Spring Boot、Maven 和 Proguard 打包程序的流程。 首先,Spring Boot 和 Maven 都是针对 Java 应用程序的工具。Spring Boot 是一个快速开发框架,可以帮助开发人员快速构建基于 Spring 的应用程序。Maven 是一个构建工具,可以帮助开发人员自动化构建、测试和部署 Java 应用程序。 Proguard 则是一个 Java 字节码混淆和压缩工具,可以将 Java 应用程序中的类、方法、变量等混淆和压缩,从而增加程序的安全性和运行速度。 接下来,我们来讲一下如何使用 Spring Boot、Maven 和 Proguard 打包程序。 1. 首先,在 pom.xml 文件中添加 Proguard 插件的配置: ```xml <build> <plugins> <plugin> <groupId>com.github.wvengen</groupId> <artifactId>proguard-maven-plugin</artifactId> <version>2.0.14</version> <executions> <execution> <phase>package</phase> <goals> <goal>proguard</goal> </goals> </execution> </executions> <configuration> <injar>${project.build.finalName}.jar</injar> <outjar>${project.build.finalName}-pro.jar</outjar> <obfuscate>true</obfuscate> <options> <option>-keep class com.example.** { *; }</option> </options> </configuration> </plugin> </plugins> </build> ``` 这里简单介绍一下配置: - `<injar>`:输入的 jar 包名称,这里使用了 Maven 的变量 `${project.build.finalName}.jar` 表示生成的 jar 包名称。 - `<outjar>`:输出的 jar 包名称,这里使用了 `${project.build.finalName}-pro.jar` 表示混淆后的 jar 包名称。 - `<obfuscate>`:是否开启混淆,默认为 true。 - `<options>`:Proguard 的配置选项,这里我们只保留了 com.example 包下的所有类和方法。 2. 执行 Maven 打包命令: ```bash mvn clean package ``` 执行完成后,会在 target 目录下生成一个混淆后的 jar 包,名称为 `${project.build.finalName}-pro.jar`。 3. 运行混淆后的 jar 包: ```bash java -jar ${project.build.finalName}-pro.jar ``` 这样,就可以运行混淆后的程序了。 以上就是 Spring Boot、Maven 和 Proguard 打包程序的简单流程。需要注意的是,混淆后的程序可能会出现运行异常,需要进行相应的调试和排查。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值