maven+proguard混淆

混淆好处:代码难以阅读,反编译,proguard混淆代码.class文件

项目用的springBoot-2.0.4版本,proguard得用6.0.3版本,不然会报错,在pom.xml文件添加混淆插件

<plugin>
    <!-- proguard混淆插件-->
    <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.3</proguardVersion>
        <!--指定混淆的jar,如springboot打出来的jar基于它混淆-->
        <injar>${project.build.finalName}.jar</injar>
        <!--输出的jar-->
        <outjar>${project.build.finalName}.jar</outjar>
        <!-- 是否混淆-->
        <obfuscate>true</obfuscate>
        <options>
            <option>-target 1.8</option> <!--指定java版本号-->
            <option>-dontshrink</option> <!--默认开启,不做收缩(删除注释、未被引用代码)-->
            <option>-dontoptimize</option><!--默认是开启的,这里关闭字节码级别的优化-->
            <option>-adaptclassstrings</option><!--混淆类名之后,对使用Class.forName('className')之类的地方进行相应替代-->
            <option>-ignorewarnings</option><!-- 忽略warn消息,如果提示org.apache.http.* 这个包里的类有问题,那么就加入下述代码:-keep class org.apache.http.** { *; }    -dontwarn org.apache.http.**-->
            <option>-keep class org.apache.logging.log4j.util.* { *; }</option>
            <option>-dontwarn org.apache.logging.log4j.util.**</option>
            <option>-keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,*Annotation*,EnclosingMethod</option><!--对异常、注解信息在runtime予以保留,不然影响springboot启动-->
            <!--不混淆所有interface接口-->
            <option>-keepnames interface **</option>
            <option>-keepclassmembers enum * { *; }</option><!--保留枚举成员及方法-->
            <option>-keepparameternames</option>
            <option>-keepclasseswithmembers public class * {
                public static void main(java.lang.String[]);}</option> <!--保留main方法的类及其方法名-->
            <!--忽略note消息,如果提示javax.annotation有问题,那麽就加入以下代码-->
            <option>-dontnote javax.annotation.**</option>
            <option>-dontnote sun.applet.**</option>
            <option>-dontnote sun.tools.jar.**</option>
            <option>-dontnote org.apache.commons.logging.**</option>
            <option>-dontnote javax.inject.**</option>
            <option>-dontnote org.aopalliance.intercept.**</option>
            <option>-dontnote org.aopalliance.aop.**</option>
            <option>-dontnote org.apache.logging.log4j.**</option>
            <option>-dontnote module-info</option>
            <!--入口程序类不能混淆,混淆会导致springboot启动不了-->
            <option>-keep class com.kafang.atgo.restful.WebApp</option>
            <option>-keepclassmembers  class com.kafang.atgo.restful.WebApp{ *;}</option>
            <option>-keep interface * extends * { *; }</option>
            <!--不混淆所有类,保存原始定义的注释-->
            <option>-keepclassmembers class * {
                @org.springframework.beans.factory.annotation.Autowired *;
                @org.springframework.beans.factory.annotation.Value *;
                }
            </option>
        </options>
        <libs>
            <!-- 添加依赖 java8-->
            <lib>${java.home}/lib/rt.jar</lib>
            <lib>${java.home}/lib/jce.jar</lib>
        </libs>
    </configuration>
    <dependencies>
        <!-- https://mvnrepository.com/artifact/net.sf.proguard/proguard-base -->
        <dependency>
            <groupId>net.sf.proguard</groupId>
            <artifactId>proguard-base</artifactId>
            <version>6.0.3</version>
        </dependency>
    </dependencies>
</plugin>

看jar是否混淆了,http://jd.benow.ca/下载jd-gui-1.4.0.jar

 

 混淆后的jar如果跑不起来,报spring容器初始化bean错误,解决如下

WebApp类加

/**
 * 主要解决proguard混淆不能指定在basePackages下面类名混淆后唯一,
 * 不同包名经常有a.class,b.class,c.class之类重复的类名,因此spring容器初始化bean的时候会报错。
 */

public static class CustomGenerator implements BeanNameGenerator{
    @Override
    public String generateBeanName(BeanDefinition definition, BeanDefinitionRegistry registry) {
        if(definition != null) {
            return definition.getBeanClassName();
        }
        return null;
    }
}

public static void main(String[] args) {

    //SpringApplication.run(WebApp.class, args);
    new SpringApplicationBuilder(WebApp.class)
            .beanNameGenerator(new CustomGenerator())
            .run(args);
}
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
好的,那我来为你介绍一下 Spring Boot、MavenProguard 打包程序的流程。 首先,Spring Boot 和 Maven 都是针对 Java 应用程序的工具。Spring Boot 是一个快速开发框架,可以帮助开发人员快速构建基于 Spring 的应用程序。Maven 是一个构建工具,可以帮助开发人员自动化构建、测试和部署 Java 应用程序。 Proguard 则是一个 Java 字节码混淆和压缩工具,可以将 Java 应用程序中的类、方法、变量等混淆和压缩,从而增加程序的安全性和运行速度。 接下来,我们来讲一下如何使用 Spring Boot、MavenProguard 打包程序。 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、MavenProguard 打包程序的简单流程。需要注意的是,混淆后的程序可能会出现运行异常,需要进行相应的调试和排查。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值