Android 代码混淆

  1. 代码混淆的作用
    代码混淆,就是把java文件在生成class文件是,类名,方法名等JAVA元素修改成没有意义的名称,同时不影响系统的运行。
  2. Proguard
    Android sdk中的Proguard工具就是一个代码混淆工具。同时可以删除无用代码,优化代码。默认情况下,Proguard会混淆全部的代码。所有的代码混淆配置,就是配置Proguard哪些文件不进行混淆。
  3. 不能混淆部分
  • 使用反射的地方。
  • 代码依赖于系统的接口。例如activity中的onCreate方法。
  • 使用第三方库时,特别指定的Proguard配置设置的文件。
  1. 进行混淆
  2. 修改build.gradle
  buildTypes {        
release {
//            debuggable false
//            shrinkResources true            
minifyEnabled true            
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'        }    }

设置minifyEnabled为true.

  1. 配置项目根目录下proguard-rules.pro文件。
  2. Proguard的配置
    -dontwarn 缺省proguard 会检查每一个引用是否正确,但是第三方库里面往往有些不会用到的类,没有正确引用。如果不配置的话,系统就会报错。
    -keep 指定的类和类成员被保留作为 入口 。
    -keepclassmembers 指定的类成员被保留。
    -keepclasseswithmembers 指定的类和类成员被保留,假如指定的类成员存在的话。
  3. 混淆过后,当app发生错误是,打印的错误信息都是使用混淆过后的名字,so,我们需要一个映射清单。build/outputs/mapping/release/mapping.txt,对照进行查看,或者使用android sdk/tools/proguard/bin/下的retrace.sh 或者groguardgui.sh把堆栈信息还原。所以没混淆一次,需要使用对应的mapping.txt。否者可能就一一对应不上了。
  4. 混淆后,我们还可以使用各个公司的加固服务,进一步保护我们源代码。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 声明 这篇文章更多的是做一个整理,内容来自于ProGuard官方文档以及各种博客等,相关文章的链接在参考目录里,感...
    夷陵小祖阅读 9,070评论 0 23
  • 什么是代码混淆 代码混淆就是将代码中的各种元素,如变量,方法,类和包的名字改写成无意义的名字,增加项目反编译后被读...
    蜗牛家族史阅读 10,584评论 1 4
  • 内容提要 本篇文章主要有三个部分,让读者读完后能自己写规则混淆项目 对Android代码怎么开启混淆做一个简单的介...
    一件小毛衣阅读 12,413评论 2 73
  • 混淆是 Android 打包过程中最重要的流程之一,基本上所有 app 都应该开启混淆,增加app的安全性。混淆其...
    shenhuniurou阅读 5,465评论 0 2
  • 混淆代码能有效防止被反编译,防止自己的劳动成果被别人窃取; ProGuard是一个开源的Java代码混淆器。它可以...
    appzy阅读 6,826评论 2 18