Android代码混淆官方实现方法

首先查看一下 “project.properties” 这个文件:

# This file is automatically generated by Android Tools.
# Do not modify this file -- YOUR CHANGES WILL BE ERASED!
#
# This file must be checked in Version Control Systems.
#
# To customize properties used by the Ant build system edit
# "ant.properties", and override values to adapt the script to your
# project structure.
#
# To enable ProGuard to shrink and obfuscate your code, uncomment this (available properties: sdk.dir, user.home):
#proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt

# Project target.
target=android-18

简单翻译一下:

这个文件又android工具自动生成,不要修改这个文件 —— 你的更改将会被删除!(这句有点不懂)

这个文件必须在版本控制系统中。

需要修改Ant构建系统的自定义属性的话,编辑"ant.properties"这个文件,重写一些值来适应你的工程结构。(翻译的很水,不要当真)

如果需要使用ProGuard来压缩和混淆代码,将下面这句解除注释(可用的属性有:sdk.dir, user.home)

翻译完毕...

到这里应该明白了,下面这行配置就是代码混淆的开关。

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt

proguard-android.txt 这个文件在SDK的 tools/proguard 文件夹中,是Google事先写好的一个代码混淆配置文件,是一个基础的android代码混淆配置文件。

继续查看 proguard-project.txt这个文件:

# To enable ProGuard in your project, edit project.properties
# to define the proguard.config property as described in that file.
#
# Add project specific ProGuard rules here.
# By default, the flags in this file are appended to flags specified
# in ${sdk.dir}/tools/proguard/proguard-android.txt
# You can edit the include path and order by changing the ProGuard
# include property in project.properties.
#
# For more details, see
# http://developer.android.com/guide/developing/tools/proguard.html

# Add any project specific keep options here:

# If your project uses WebView with JS, uncomment the following
# and specify the fully qualified class name to the JavaScript interface
# class:
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}

再次秀一下我蹩脚的英语,简单翻译一下:

如果需要使用ProGuard,编辑project.properties文件,根据描述定义proguard.config。

可以在这儿添加具体的代码混淆规则。

默认情况下,这个文件中的标志附加到${sdk.dir}/tools/proguard/proguard-android.txt指定的标志。

你可以通过改变 project.properties 中的 ProGuard的include属性来编辑路径和指令。

...

更多的信息,请查看http://developer.android.com/guide/developing/tools/proguard.html。

在这儿添加工程的具体的keep options:

...

如果你的工程使用了WebView中的JS,解除下面的注释,并且指定JavaScript接口类的全名。(也就是是忽略js部分,不进行混淆,方法是解除注释,将fqcn.of.javascript.interface.for.webview替换为与JS绑定的类名。)

#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
# public *;
#}

翻译完毕...

通过这两个文件的注释可以得出结论:

proguard.config=${sdk.dir}/tools/proguard/proguard-android.txt:proguard-project.txt 有了这一句就启用的代码混淆。

proguard-android.txt 是基础的Android代码混淆规则,如果需要添加规则,添加到proguard-project.txt

如果没有引入第三方的库,一般情况下 proguard-android.txt 的规则是够用的,但是如果有第三方的库,在混淆的时候要把第三方的库忽略掉,这是就需要在 proguard-project.txt 文件中添加规则。(android.support.** 已经在proguard-android.txt做了处理,所以如果使用了android.support.v4,就不用添加代码混淆的规则了)。

对第三分库的处理,参考:http://blog.csdn.net/u_xtian/article/details/7495023

具体做法,在 proguard-project.txt 添加:

-libraryjars **.jar (声明lib文件)

-dontwarn com.xx.bbb.** (不提示警告)
-keep class com.xx.bbb.** { *;} (不进行混淆)

例如百度地图:

-libraryjars libs/baidumapapi_v2_1_3.jar

-dontwarn com.baidu.mapapi.**
-dontwarn com.baidu.platform.**
-dontwarn com.baidu.location.**
-dontwarn com.baidu.vi.**
-dontwarn vi.com.gdi.bgl.android.**

-keep class com.baidu.mapapi.** {*; }
-keep class com.baidu.platform.** {*; }
-keep class com.baidu.location.** {*; }
-keep class com.baidu.vi.** {*; }
-keep class vi.com.gdi.bgl.android.** {*; }

可能有人很疑惑,不进行代码混淆的方法我知道,但这些包名去那里找啊,其实很简单。打开Android Private Libraries就能看到。

Android代码混淆官方实现方法

上一篇:【转】C++ Incorrect Memory Usage and Corrupted Memory(模拟C++程序内存使用崩溃问题)


下一篇:React.js学习之理解JSX和组件