大家所知的Android中的“混淆”可以分为两部分,一部分是 Java 代码的优化与混淆,依靠 proguard 混淆器来实现;另一部分是资源压缩,从而可以减少包体积。
一般应用release发布的时候都会选择开启混淆,防止应用被反编译后窃取源码。在HarmonyOS元服务开发中,我们也可以通过开启混淆提高应用的安全性和压缩包体积。元服务低版本工程中使用的gradle作为构建工具,下文以API6 JS工程为例,高版本暂时不做相关说明。
【开启混淆】
在HarmonyOS工程开启代码混淆很简单,只需要在模块级的build.gradle中的buildTypes中设置以下代码就可以了:
buildTypes {
release {
proguardOpt {
proguardEnabled true //开启代码混淆功能
rulesFiles 'proguard-rules.pro' // 配置混淆规则文件相对路径
consumerRulesFiles 'consumer-rules.pro' // 配置打包混淆规则文件相对路径,仅在HarmonyOS Library模块中配置
}
}
}
混淆会通过缩短应用的类、方法和字段的名称来缩减应用的大小。混淆后代码大概如下图中所示:
com.example.atomictest.widget.controller.FormControllerManager -> com.example.atomictest.a.a.b:
ohos.hiviewdfx.HiLogLabel TAG -> a
com.example.atomictest.widget.controller.FormControllerManager managerInstance -> b
java.util.HashMap controllerHashMap -> c
ohos.app.Context context -> d
ohos.data.preferences.Preferences preferences -> e
void <init>(ohos.app.Context) -> <init>
com.example.atomictest.widget.controller.FormControllerManager getInstance(ohos.app.Context) -> a
com.example.atomictest.widget.controller.FormController createFormController(long,java.lang.String,int) -> a
com.example.atomictest.widget.controller.FormController getController(long) -> a
com.example.atomictest.widget.controller.FormController newInstance(java.lang.String,int,ohos.app.Context) -> a
void deleteFormController(long) -> b
java.lang.String getClassNameByFormName(java.lang.String) -> a
void <clinit>() -> <clinit>
【另一个问题】
当我们使用混淆配置后,对外发布的应用运行在手机上时,发生异常的报错也不会是原来的包名和类名,都会变成a.b.c这种混淆后代码,行号也会发生变化。对于熟悉Android开发的同学,大家一定想到了使用mapping.txt文件来还原混淆后的代码,不了解的同学可以看下面这个文档:Android 利用 proguardgui.bat 还原混淆代码 - 知乎 (zhihu.com)
Android中的mapping.txt 文件会在 模块/outputs/mapping/release/mapping.txt 中,但是通过相同的方法我们在DevEco Studio工程目录下是找不到mapping.txt,这是为什么呢?
【寻找mapping.txt】
造成这个问题的原因是Android中使用的R8代替了Proguard ,因此不需要增加额外的配置就可以直接生成mapping.txt文件。HarmonyOS中使用的Proguard,针对Proguard,我们需要在proguard-rules.pro配置以下代码才可以生成mapping.txt
printmapping mapping.txt
除了printmapping以外,还有以下常用的配置命令,提供给大家参考
# 包内所有 class 的内部结构
-dump dump.txt
# 没有被混淆的类和成员
-printseeds seeds.txt
# 被移除的代码
-printusage usage.txt
最后在我们通过Build HAP,生成HAP,就可以在/entry/build/intermediates/proguard_profile/release目录下看到生成的这些文件了。
欲了解更多更全技术文章,欢迎访问https://developer.huawei.com/consumer/cn/forum/?ha_source=zzh