JAVA之代码混淆proguard

本文详细介绍 ProGuard 的核心功能,包括代码缩减、优化及混淆,并解释如何配置类规范以避免混淆关键代码,确保程序正常运行。此外,还提供了调试混淆后问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

官方网站用法

http://proguard.sourceforge.net/index.html#/manual/examples.html

proguard主要三部分功能

缩减代码、优化代码、混淆代码。三部分功能都可以在配置文件里配置不启用此功能。
#Shrink Options
#不缩减代码
-dontshrink

#Optimization Options
#优化代码
-dontoptimize

#Obfuscate Options 
#-不混淆输入的类文件 
#-dontobfuscate 

用法

Class Specifications 类规范,详细定义了类、接口、枚举、成员、方法等 -keep options 和-assumenosideeffects option的保留规则。
匹配符*在类、接口、枚举、成员、方法的使用方法。
1.在配置文件中例如xml中引用到的类名,不能混淆重命名。因为配置时需要通过配置文件路径加载类。
android中的例如Activity的配置-keep public class * extends android.app.Activity(只保留类名,类名不会混淆重命名,但是其成员和方法会混淆)在xml中出现的有Activity、Application、Service、BroadcastReceiver、ContentProvider、Fragment、Context、LinearLayout、View等自定义视图。
2.保留sdk系统自带的一些内容。
-keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,*Annotation*,EnclosingMethod
比如-keepattributes *Annotation*会保留Activity的被@Override注释的方法onCreate、onDestroy方法等。
3.资源类变量需要保留
-keepclassmembers class **.R$* {
    public static <fields>;
}
4.保留第三方jar包的所有类及其成员和方法,例如{ *;}匹配了类内的所有成员和方法。
#jar config
-dontwarn org.apache.log4j.**
-keep class org.apache.log4j.** { *;}
5.缺省情况下,proguard 会混淆所有代码,但是下面几种情况是不能改变java 元素的名称,否则就会这样就会导致程序出错。
(1) 我们用到反射的地方。
(2) 我们代码依赖于系统的接口,比如被系统代码调用的回调方法,这种情况最复杂。
(3) 是我们的java 元素名称是在配置文件中配置好的。
6.对出现问题的类的处理。 -keep用法区别
-dontwarn 缺省proguard 会检查每一个引用是否正确,但是第三方库里面往往有些不会用到的类,没有正确引用。如果不配置的话,系统就会报错。
-keep 指定的类和类成员被保留作为 入口 。
-keepclassmembers 指定的类成员被保留。
-keepclasseswithmembers 指定的类和类成员被保留,假如指定的类成员存在的话。
(1)保留某个类名不被混淆
-keep public class com.app.common.bean.Customer
(2)保留类及其所有成员不被混淆
-keep public class com.app.common.bean.Customer { *;}
或者
-keepclasseswithmembers class com.app.common.bean.Customer {
    <init>;#匹配所有构造函数
    <fields>;#匹配所有成员
    <methods>;#匹配所有方法
(3)只保留类名及其部分成员不被混淆
-keep public class com.ebt.app.common.bean.Customer { 
    static final<fields>;
    private void get*();
}
(4)保留某个包下的所有了类
-keep class com.google.** { *;}  
7.proguard 问题和风险
代码混淆后虽然有混淆优化的好处,但是它往往也会带来如下的几点问题
1,混淆错误,用到第三方库的时候,必须告诉 proguard 不要检查,否则proguard 会报错。
2,运行错误,当code 不能混淆的时候,我们必须要正确配置,否则程序会运行出错,这种情况问题最多。

3,调试苦难,出错了,错误堆栈是混淆后的代码 ,自己也看不懂。

8.混淆后出现问题的调试方法
(1)打印日志,保留异常,源文件行数信息。
 -printmapping out.map  
 -renamesourcefileattribute SourceFile  
 -keepattributes Exceptions,SourceFile  
(2)确定哪一行哪个类出错。
也可以使用Log或者System.out在可能出错的行前后打印测试日志,以确定具体出错的类是哪一个。来决定是否保留。

使用gradle构建android工程配置混淆方法
minifyEnabled true
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-project.txt'

扫码关注公众号,共同学习进步。



### Java代码混淆工具及其实现方法 #### 工具介绍 Java代码混淆可以通过多种工具实现,其中ProGuard是最常用的开源工具之一。它能够移除未使用的代码并重命类、变量和方法为简短且难以理解的字[^1]。除此之外,还有商业化的混淆工具如Allatori,提供了更高级的功能和支持。 #### ProGuard的使用方式 对于Maven项目,`proguard-maven-plugin`插件允许开发者直接在`pom.xml`中定义所有的ProGuard指令。这使得构建过程更加自动化,并减少了手动操作的可能性。以下是基本配置示例: ```xml <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> <options> <option>-dontnote</option> <option>-dontwarn</option> <option>-keep class com.example.Main { *; }</option> </options> <libs> <lib>${java.home}/lib/rt.jar</lib> </libs> </configuration> </plugin> ``` 此配置片段展示了如何设置保留特定类混淆以及忽略警告信息。 #### Allatori的应用场景 当需要更高层次的安全保障时,可以选择像Allatori这样的商业化解决方案。它的优势在于提供更为精细的控制选项,例如保持某些访问级别以上的成员变,而对其余部分执行全面混淆处理[^5]。下面是一个简单的XML配置例子: ```xml <config> <input> <jar in="original.jar" out="obfuscated.jar"/> </input> <keep-names> <class access="public+"> <field access="public+"/> <method access="public+"/> </class> </keep-names> </config> ``` 这段代码表明只有公开级别的组件才会免受混淆影响[^5]。 #### 常见注意事项 尽管进行了充分的混淆处理,仍需注意一些细节问题才能确保最终效果理想。例如,确认所有非公共接口均已被适当转换;另外,由于字符串字面量会自动参与混淆流程,因此建议将其封装于函数内部调用来达到隐藏目的[^3]。 #### 结论 综上所述,无论是采用免费开源方案还是付费专业服务,在实施前都应仔细评估各自优劣以便做出最佳决策。同时也要意识到没有任何一种技术手段可以做到绝对防护,合理权衡安全性和维护便利性才是关键所在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值