当前位置: 代码迷 >> 综合 >> proguard-java代码混淆
  详细解决方案

proguard-java代码混淆

热度:38   发布时间:2023-11-14 02:17:25.0

proguard-java代码混淆

  • 前言
  • pom文件配置
  • 总结

前言

许多场景需要对java代码混淆加密,防止被人反编译知道查看道源码,现在有好多代码混淆工具。
现在业内好多代码混淆工具都是需要进行下载,通过工具进行混淆,对于我们开发人员很不方便,于是本人找了下proguard来混淆打包
本文提供的springboot+maven+idea来进行配置的。

pom文件配置

首先是pom文件中添加proguard插件配置

<plugin><groupId>com.github.wvengen</groupId><artifactId>proguard-maven-plugin</artifactId><version>2.0.11</version><executions><execution><!-- 混淆时刻,这里是打包的时候混淆--><phase>package</phase><goals><!-- 指定使用插件的混淆功能 --><goal>proguard</goal></goals></execution></executions><configuration><proguardVersion>6.2.2</proguardVersion><injar>${
    project.build.finalName}.jar</injar><outjar>${
    project.build.finalName}.jar</outjar><!-- 开启混淆 --><obfuscate>true</obfuscate><options><!-- 忽略所有警告,否则有警告的时候混淆会停止 --><option>-ignorewarnings</option><!-- 不做收缩(删除注释、未被引用代码)--><option>-dontshrink</option><!-- 不做优化(变更代码实现逻辑)--><option>-dontoptimize</option><!-- 优化时允许访问并修改有修饰符的类和类的成员 --><option>-allowaccessmodification</option><!-- 确定统一的混淆类的成员名称来增加混淆 --><option>-useuniqueclassmembernames</option><!-- 不混淆非公用类文件及成员 --><option>-dontskipnonpubliclibraryclasses</option><option>-dontskipnonpubliclibraryclassmembers</option><!-- 该选项将用新的类名替换反射方法调用中的所有字符串。例如,调用Class.forName('className'--><option>-adaptclassstrings</option><!-- 此选项会将所有原始方法参数保存在-keep节中定义的文件中,否则所有参数名称都将被混淆。--><option>-keepparameternames</option><!-- 不混淆所有特殊的类--><option>-keepattributesExceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,*Annotation*,EnclosingMethod</option><!-- 自定义需要混淆的地方 --><!-- 1.首先混淆自己项目下所有文件内容 com.test包下所有的类--><option>-keep class !com.test.** {
     *; }</option><!-- 2.排除不需要混淆的文件内容 --><option>-keep class com.test.Application {
     *; }</option></options></configuration><dependencies><dependency><groupId>net.sf.proguard</groupId><artifactId>proguard-base</artifactId><version>6.2.2</version></dependency></dependencies></plugin>

总结

在配置pom.xml中添加上述插件配置,打包便是混淆加密的。
如果在使用的过程中有什么疑问,可以跟小编联系,大家一起讨论。

  相关解决方案