九、Android混淆

Android混淆没什么特别的.就是能让显得牛逼一点.让破解你软件的人痛苦很多.接下来给大家讲讲混淆的基本概念,Android混淆主要分为四个阶段

  • 压缩(Shrink): 侦测并移除代码中无用的类、字段、方法、和特性(Attribute)。
  • 优化(Optimize): 分析和优化字节码。
  • 混淆(Obfuscate): 使用a、b、c、d这样简短而无意义的名称,对类、字段和方法进行重命名。
    前面三个步骤使代码size更小,更高效,也更难被逆向工程。
  • 预检(Preveirfy): 在java平台上对处理后的代码进行预检。

开启混淆后,默认上述四个全部开启

加密输出的文件

构建时Proguard都会输出下列文件:

  • dump.txt —- 说明APK中所有类文件的内部结构
  • mapping.txt —- 提供原始与混淆过的类、方法和字段名称之间的转换
  • seeds.txt —- 列出未进行混淆的类和成员
  • usage.txt —- 列出从APK移除的代码
    这些文件保存在/build/outputs/mapping/release目录下。

检验混淆后的一键反编译工具

直接运行jdax-gui.bat.把apk拖进去即可
https://github.com/skylot/jadx/releases

1.Shrink 压缩 移除无用的类、字段、方法、属性

证明Shrink的存在.我的办法是对比混淆前后的class.查看usage.txt中的内容
测试代码如下:
这里写图片描述
MaingActivity的代码:
这里写图片描述
截图这么多就是为了说明remove没有被用到….,开启混淆后.
这里写图片描述
remove.java被无情的杀害了.我们来看看usage.txt
这里写图片描述
确认杀害完毕…..

2.Obfuscate 使用a、b、c、d,对类、字段和方法进行重命名。

接下来我们看一下.使用remove.实际代码
这里写图片描述
反编译得到的代码

3.混淆的语法

常用基本语法

-keep class cn.hello.test.**  //保留当前包下所有类名,方法名和变量被混淆
-keep class cn.hello.test.*   //保留当前包下类名,子包依然混淆,方法名和变量被混淆
-keep class cn.hello.test.* {*;} //保留当前包下所有资源
-dontwarn cn.hello.test.**   //不提示warning
-dontnot cn.hello.test.**    //不提示note

4.哪些不能混淆

  • native方法
  • 四大组件
  • Gson实体
  • 被反射的类
  • 第三方库的混淆规则要注意
  • 其他…

5.反混淆

在SDK的安装目录下\tools\proguard\lib找到proguardgui,双击进入ProGuard工具,点击ReTrace按钮,将mapping文件和log信息导进去,点击ReTrace!就可以看到log的错误信息

6.混淆字符配置

配置proguard模糊字典:
1.在proguard-rules.pro里配置:
-obfuscationdictionary dictionary_rules.txt
-classobfuscationdictionary dictionary_rules.txt
2.定义字典字符映射(与proguard-rules.pro在同一目录下)
dictionary_rules.txt
定义如下(当然可以配置中文,越凌乱越好):

混淆结果:

模糊混淆选项说明:
-obfuscationdictionary filename
指定外部模糊字典
-classobfuscationdictionary filename
指定class模糊字典
-packageobfuscationdictionary filename
指定package模糊字典

参考文章:
https://www.jianshu.com/p/b499b46203ed
https://www.jianshu.com/p/7436a1a32891

Android 开发中,代码混淆是保护应用安全、减小 APK 体积的重要手段。ProGuard 是 Android 官方早期提供的代码混淆工具,它通过对类名、方法名和字段名进行重命名,降低代码的可读性,并通过优化字节码提升性能[^2]。 ### 启用 ProGuard 混淆Android 项目中启用 ProGuard 非常简单,只需在模块级的 `build.gradle` 文件中配置 `minifyEnabled` 和 `proguardFiles` 即可: ```gradle android { buildTypes { release { minifyEnabled true proguardFiles getDefaultProguardFile('proguard-android-optimize.txt'), 'proguard-rules.pro' } } } ``` - `minifyEnabled true` 表示启用代码混淆。 - `proguardFiles` 指定使用的 ProGuard 配置文件,通常包括系统默认的优化规则和自定义规则文件 `proguard-rules.pro`[^4]。 ### 编写 ProGuard 混淆规则 ProGuard 的核心在于编写合适的混淆规则。规则文件通常位于模块根目录下的 `proguard-rules.pro` 文件中。 #### 常用规则示例: ```proguard # 保留所有 Activity 类不被混淆 -keep public class * extends android.app.Activity # 保留所有 Application 类不被混淆 -keep public class * extends android.app.Application # 保留 Parcelable 实现类及其构造方法 -keep class * implements android.os.Parcelable { public static final android.os.Parcelable$Creator *; } # 保留所有使用了注解的类成员 -keepclassmembers class * { @android.webkit.JavascriptInterface <methods>; } # 保留枚举类 -keepclassmembers enum * { public static **[] values(); public static ** valueOf(java.lang.String); } ``` 这些规则确保关键的 Android 组件和功能在混淆过程中不会被错误地移除或重命名[^1]。 ### 查看混淆日志与调试 构建混淆后的 APK 后,可以通过 `mapping.txt` 文件来查看混淆前后类名、方法名和字段名的映射关系。该文件通常位于 `app/build/outputs/mapping/release/` 目录下。 如果应用在运行时出现异常,可以通过 `retrace` 工具将混淆后的堆栈信息还原为原始类名和方法名: ```bash retrace.sh -verbose mapping.txt obfuscated_stack_trace.txt ``` 这有助于定位混淆导致的运行时错误[^1]。 ### 常见问题与解决方法 - **类或方法被错误移除**:使用 `-keep` 指令保留关键类或方法。 - **资源引用错误**:某些资源类(如 `R` 类)应保留不被混淆。 - **第三方库未正确处理**:为第三方库添加特定的 ProGuard 规则,通常可以在库的文档中找到。 - **启动崩溃或功能异常**:检查是否遗漏了对反射调用、JNI 接口或动态加载类的保留规则。 ### 优化建议 - 在启用混淆的同时,建议开启资源压缩和未用资源移除功能,以进一步减小 APK 体积: ```gradle android { buildTypes { release { minifyEnabled true shrinkResources true proguardFiles ... } } } ``` - 使用 `proguard-android-optimize.txt` 而非 `proguard-android.txt` 可启用更高级的优化策略,提升应用性能[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值