Android混淆机制

java代码的混淆


常见的混淆的方式有两种, Proguard (免费)和 DexGuard (要钱)。

  • Proguard 与 DexGuard 的关系

    DexGuard 是基于 ProGuard 的。这就是为什么它是如此的原因很容易升级到DexGuard。但是这两种产品提供广泛不同的功能。ProGuard的是Java字节码通用的优化,同时 DexGuard 提供了先进的 Android 应用程序的保护。在这篇博客中,你会发现 ProGuard,并将 DexGuard 之间的差别的概述。详情

Proguard

Proguard 4个特性

在 Android 中使用 Proguard 不仅仅可以为我们提供混淆的功能,事实上 Proguard 还提供了以下4点功能

  1. 混淆:使用无意义的简短字母组合对类名、方法名、属性进行重命名。
  2. 压缩: java 源代码被编译成字节码。 Proguard 的压缩功能通过分析字节码,能够检测并移除没有使用的类、字段、方法等。
  3. 优化:优化字节码,同时移除没有使用到的命令。
  4. 预校验:对上述处理后的代码进行预校验。
Proguard 的使用

在需要混淆的 Module 中的 build.gradle 文件下添加如下配置即可。

android {
 ...
    buildTypes {
        release {
            minifyEnabled true // true 表示使用 proguard
            proguardFile 'proguard-android.cfg'//项目中的混淆配置文件

        }
    }
             }

dexGuard

C/C++ 代码的混淆


native层混淆并没有统一的标准方案,常见的 方法是使用花指令。使得native层在被反编译时出错

资源文件的混淆


和native层一样并没有统一的标准方案,目前有两个方案,美团和微信两种。微信的已开源点击

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android 应用中为 Kotlin 代码添加混淆规则和为 Java 代码添加混淆规则是类似的,只是混淆规则的语法略有不同。 下面是一些常见的针对 Kotlin 代码的混淆规则: ``` # 保留 Kotlin 标准库中的所有类和成员 -keep class kotlin.** { *; } -keepclassmembers class kotlin.** { *; } # 保留 Kotlin 协程库中的所有类和成员 -keep class kotlinx.coroutines.** { *; } -keepclassmembers class kotlinx.coroutines.** { *; } # 如果使用了 Kotlin 的反射机制,则需要保留相关类和成员 -keepclassmembers class **.Kt { kotlin.Metadata metadata; <methods>; } # 如果使用了 Kotlin 的注解,则需要保留相关类和成员 -keep class **$$* { *; } # 如果使用了 Kotlin 的内联函数,则需要保留相关类和成员 -keepclassmembers class ** { <init>(); <clinit>(); **.Companion # *; **.Companion # *(...); **.Companion # *$default (...); **.Companion # *$annotations (...); **.Companion # *$Instance (...); **.Companion # *$Instance$annotations (...); **.Companion # *$EnumType (...); } # 如果使用了 Kotlin 的扩展函数,则需要保留相关类和成员 -keepclassmembers class ** { <init>(); <clinit>(); **.Companion # *; **.Companion # *(...); **.Companion # *$default (...); **.Companion # *$annotations (...); **.Companion # *$Instance (...); **.Companion # *$Instance$annotations (...); **.Companion # *$EnumType (...); kotlin.ExtensionFunctionType # *; } # 如果使用了 Kotlin 的数据类,则需要保留相关类和成员 -keepclassmembers class ** { <init>(...); <init>(...); **.copy$default (...); **.component* (...); **.copy (...); **.equals (...); **.hashCode (...); **.toString (...); } # 如果使用了 Kotlin 的 Sealed 类,则需要保留相关类和成员 -keepclassmembers class ** { <init>(); <clinit>(); **.Companion # *; **.Companion # *(...); **.Companion # *$default (...); **.Companion # *$annotations (...); **.Companion # *$Instance (...); **.Companion # *$Instance$annotations (...); **.Companion # *$EnumType (...); **.SealedSubclass # *; } ``` 这些混淆规则可以根据实际情况进行调整和修改。需要注意的是,如果你的代码中使用了一些第三方库或框架,还需要为这些库或框架添加相应的混淆规则。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值