Android 混淆-详细解读
ProGuard
是一个免费的Java
类文件缩小,优化,混淆和预验证的工具。它检测和删除未使用的类,字段,方法和属性;优化字节码并删除未使用的指令;它使用短的无意义的名称重命名剩余的类,字段和方法。所得到的应用程序和库更小,更快,并且更好地针对逆向工程进行优化。
一、混淆的四个功能
- 压缩:移除无效的类、属性、方法等;
- 优化:优化字节码,并删除未使用的结构;
- 混淆:类名、属性名、方法名混淆成难度字母;
- 预效验
minifyEnabled
改为true
buildTypes { release { minifyEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } }
二、不能参与混淆的
-
AndroidManifest
中配置的类,比如四大组件和Application
类。 -
Fragment
不参与混淆app包下和v4包下的分别keep下 - 所有实现了
Serializable
接口的类成员 - JNI调用的方法
- 反射用到的类
- 枚举
- 项目中暴露的
JS
接口类及其调用的方法的声明也不能混淆; - Layout文件引用到的自定义View
- 注解的类或参数或函数不能参与混淆
- 一些引入的第三方库(一般都会有混淆说明的)
三、AAR对外提供的接口的处理
把aar对外提供的接口,统一到一个类中,在混淆文件中加上keep方法,让这个类不被混淆,同时R文件也能混淆
例如
-dontwarn okhttp3.** -keep class okhttp3.**{*;}
四、混淆的文件示例
以下代码的因包名而变化
#混淆的初始化配置############################################## -ignorewarnings # 忽略警告,避免打包时某些警告出现 -optimizationpasses 5 # 指定代码的压缩级别 -dontusemixedcaseclassnames # 是否使用大小写混合 -dontskipnonpubliclibraryclasses # 是否混淆第三方jar -dontpreverify # 混淆时是否做预校验 -verbose # 混淆时是否记录日志 -optimizations !code/simplification/arithmetic,!field/*,!class/merging/* # 混淆时所采用的算法 #################################################################################################### ## 1.四大组件和Application类不参与混淆 -keep public class * extends android.app.Activity -keep public class * extends android.app.Service -keep public class * extends android.content.BroadcastReceiver -keep public class * extends android.content.ContentProvider -keep public class * extends android.app.Application ## 2.Fragment不需要在AndroidManifest.xml中注册,需要额外保护下 -keep public class * extends android.support.v4.app.Fragment -keep public class * extends android.app.Fragment -keep public class * extends android.support.v4.app.FragmentActivity ## 3.保持所有实现 Serializable 接口的类成员 -keepclassmembers class * implements java.io.Serializable { static final long serialVersionUID; private static final java.io.ObjectStreamField[] serialPersistentFields; private void writeObject(java.io.ObjectOutputStream); private void readObject(java.io.ObjectInputStream); java.lang.Object writeReplace(); java.lang.Object readResolve(); } ## 6.枚举不被混淆 -keepclassmembers enum * { public static **[] values(); public static ** valueOf(java.lang.String); } ## 7.MyJavaInterface不能混淆,其调用的方法声明也不能混淆,所以还要添加如下混淆 -keepclassmembers class com.example.administrator.webviewpagescannerapp.other.MJavascriptInterface{ public *; } -keepattributes *JavascriptInterface* // 注解不参与混淆 -keepattributes *Annotation* ## 8.Layout文件引用到的自定义View -keep public class * extends android.view.View { public <init>(android.content.Context); public <init>(android.content.Context, android.util.AttributeSet); public <init>(android.content.Context, android.util.AttributeSet, int); public void set*(...); } ##########################实体类不参与混淆############################ -keep class ai.botbrain.ttcloud.sdk.entity.** { *; } ######################对外提供的接口类不参与混淆################################ -keep class ai.botbrain.ttcloud.api.** { *; } #################################################################################################### -dontwarn android.support.**
五、混淆时候遇到的ERROR
混淆遇到的错误
Warning: there were 3 instances of library classes depending on program classes. You must avoid such dependencies, since the program classes will be processed, while the library classes will remain unchanged. (http://proguard.sourceforge.net/manual/troubleshooting.html#dependency)
解决
-ignorewarnings
六、混淆的gradle配置
默认情况下,Android Plugin会自动给项目设置同时构建应用的debug
和release
版本。两个版本之间不同主要围绕着能否在一个安全设备上调试,以及APK
如何签名。
所以当想在debug
时候关闭混淆功能时,同时把release
和debug
下的minifyEnabled
置为false
。
release { // 是否混淆 minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } debug { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' }
七、给别人提供混淆的AAR注意事项
需求:把项目中的某一个模块,打包成一个混淆的aar,集成到其他的项目中,同时暴露的接口不混淆,这个aar的依赖库跟其他项目的依赖库不能冲突。
模块中引入的jar
在以下情况下是混淆不成功的:
1.假设有两个模块,moduleA
和moduleB
moduleA
依赖moduleB
moduleB
中引入了第三方的jar
,混淆的配置是在moduleA
中,这种情况下,moduleB
中的jar
是不被混淆的。
2.引入的jar
包是以网络库方式的依赖,是不被混淆的。
知道了以上注意点,可以更好的为别人提供混淆后的aar,并减小类的冲突。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
Android开发之编写第一个Android应用程序实现按钮和复选框
搞Android系统这么久了,说实话,我连apk怎么写还真是不会,说实话能够看懂,简单改改就不错了,说来惭愧,我是嵌入式出身。最近开始学习Android应用开发,和我的底层结合起来,为了工作,咬着牙也要学下去!!! 首先,我使用的是Android Studio这个软件。 上谷歌中国网就可以下载到了,地址如下: https://developer.android.google.cn/develop/index.html 编译环境配置,找百度看看就行了,这里不哆嗦。 安装好后,有一些工具没有安装到位可能会报下面类似的错误,看着下面的log提示找解决方案就行了,不懂就百度。作为一个开发人员,错误信息要会看。 程序实现的界面,功能如下: (1)按下ALL ON/OFF,所有的复选框checkbox被全部选中或者全部不选中,且按钮里的字符串变成ALL ON或者ALL OFF,并打印消息led all on或者led all off (2)勾选或者不勾选checkbox,会选中对应的LEDx,并打印对应LED on或者 LED off 首先看下Activity_main.xml,这个...
- 下一篇
iOS:授权用户定位NSLocationManager的使用
请求用户批准定位: 在iOS8,要想获得用户的位置,必须经过用户批准授权 开发者可以在Info.plist中添加两个配置项 –NSLocationAlwaysUsageDescription –NSLocationWhenInUseUsageDescription 通过两个实例方法获取授权 –requestWhenInUseAuthorization –requestAlwaysAuthorization ====================================================== 用到的转换位置信息的编解码类:CLGeocoder //声明一个完成信息转换后的block函数 typedefvoid(^CLGeocodeCompletionHandler)(NSArray*placemarks,NSError*error); @interfaceCLGeocoder :NSObject @property(nonatomic,readonly,getter=isGeocoding)BOOLgeocoding; //是否正在编码 //将地图上的位...
相关文章
文章评论
共有0条评论来说两句吧...