本文出自:https://blog.csdn.net/DT235201314/article/details/80195146

一丶慨述

最近连续遇到debug版本测试没问题,正式包测试出问题的情况。

问题定位:未做代码混淆规则处理

例:

1.商城项目新增JS方法调用,正式包点击没反应;

2.极光推送打正式包报错,正式版无法注册。(此项目之前压根没做混淆规则处理)

处理方法:见正文(copy相关不被混淆命令)

二丶正文

1.Android studio  build相关配置

buildTypes {    debug {        buildConfigField "boolean", "DEBUG_MODE", "true"        buildConfigField "String", "BASE_URL", "\"http://\""        buildConfigField "String", "LOGIN_URL", "\"http://\""    }    release {        buildConfigField "boolean", "DEBUG_MODE", "false"        buildConfigField "String", "BASE_URL", "\"\""        buildConfigField "String", "LOGIN_URL", "\"\""        minifyEnabled true        shrinkResources true        proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'        manifestPlaceholders = [        ]    }}

minifyEnabled为true表示需要混淆

shrinkResources为true表示删除没用到的资源

可见debug包一般是不需要混淆了,这样编译时节省时间。

2.ProGuard作用

压缩: 移除无效的类、属性、方法等,默认开启

-dontshrink 关闭压缩

优化: 优化字节码,并删除未使用的结构,默认开启;

-dontoptimize  关闭优化
-optimizationpasses n 表示proguard对代码进行迭代优化的次数,Android一般为5

混淆: 将类名、属性名、方法名混淆为难以读懂的字母,比如a,b,c,默认开启;

-dontobfuscate 关闭混淆

混淆后默认会在工程目录app/build/outputs/mapping/release下生成一个mapping.txt文件,这就是混淆规则,我们可以根据这个文件把混淆后的代码反推回源本的代码,所以这个文件很重要,注意保护好。原则上,代码混淆后越乱越无规律越好,但有些地方我们是要避免混淆的,否则程序运行就会出错,所以就有了后面周末线上版本出问题,被迫拉去改BUG,所以有了这边文章。

3.混淆注意点(哪些不需要混淆)

1.使用了自定义控件那么要保证它们不参与混淆;
2.使用了枚举要保证枚举不被混淆;
3.对第三方库中的类不进行混淆;
4.运用了反射的类也不进行混淆;
5.使用了 Gson 之类的工具要使 JavaBean 类即实体类不被混淆;
6.在引用第三方库的时候,一般会标明库的混淆规则的,建议在使用的时候就把混淆规则添加上去,免得到最后才去找;
7.有用到 WebView 的 JS 调用也需要保证写的接口方法不混淆(被迫周末赶集加班的原因);
8.Parcelable 的子类和 Creator 静态成员变量不混淆,否则会产生 Android.os.BadParcelableException;

4.常见混淆模板

############################################### 对于一些基本指令的添加############################################### 代码混淆压缩比,在0~7之间,默认为5,一般不做修改-optimizationpasses 5# 混合时不使用大小写混合,混合后的类名为小写-dontusemixedcaseclassnames# 指定不去忽略非公共库的类-dontskipnonpubliclibraryclasses# 这句话能够使我们的项目混淆后产生映射文件# 包含有类名->混淆后类名的映射关系-verbose# 指定不去忽略非公共库的类成员-dontskipnonpubliclibraryclassmembers# 不做预校验,preverify是proguard的四个步骤之一,Android不需要preverify,去掉这一步能够加快混淆速度。-dontpreverify# 保留Annotation不混淆-keepattributes *Annotation*,InnerClasses# 避免混淆泛型-keepattributes Signature# 抛出异常时保留代码行号-keepattributes SourceFile,LineNumberTable# 指定混淆是采用的算法,后面的参数是一个过滤器# 这个过滤器是谷歌推荐的算法,一般不做更改-optimizations !code/simplification/cast,!field/*,!class/merging/*############################################### Android开发中一些需要保留的公共部分############################################### 保留我们使用的四大组件,自定义的Application等等这些类不被混淆# 因为这些子类都有可能被外部调用-keep public class * extends android.app.Activity-keep public class * extends android.app.Appliction-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.backup.BackupAgentHelper-keep public class * extends android.preference.Preference-keep public class * extends android.view.View-keep public class com.android.vending.licensing.ILicensingService# 保留support下的所有类及其内部类-keep class android.support.** {*;}# 保留继承的-keep public class * extends android.support.v4.**-keep public class * extends android.support.v7.**-keep public class * extends android.support.annotation.**# 保留R下面的资源-keep class **.R$* {*;}# 保留本地native方法不被混淆-keepclasseswithmembernames class * {    native ;}# 保留在Activity中的方法参数是view的方法,# 这样以来我们在layout中写的onClick就不会被影响-keepclassmembers class * extends android.app.Activity{    public void *(android.view.View);}# 保留枚举类不被混淆-keepclassmembers enum * {    public static **[] values();    public static ** valueOf(java.lang.String);}# 保留我们自定义控件(继承自View)不被混淆-keep public class * extends android.view.View{    *** get*();    void set*(***);    public (android.content.Context);    public (android.content.Context, android.util.AttributeSet);    public (android.content.Context, android.util.AttributeSet, int);}# 保留Parcelable序列化类不被混淆-keep class * implements android.os.Parcelable {    public static final android.os.Parcelable$Creator *;}# 保留Serializable序列化的类不被混淆-keepclassmembers class * implements java.io.Serializable {    static final long serialVersionUID;    private static final java.io.ObjectStreamField[] serialPersistentFields;    !static !transient ;    !private ;    !private ;    private void writeObject(java.io.ObjectOutputStream);    private void readObject(java.io.ObjectInputStream);    java.lang.Object writeReplace();    java.lang.Object readResolve();}# 对于带有回调函数的onXXEvent、**On*Listener的,不能被混淆-keepclassmembers class * {    void *(**On*Event);    void *(**On*Listener);}# webView处理,项目中没有使用到webView忽略即可-keepclassmembers class fqcn.of.javascript.interface.for.webview {    public *;}-keepclassmembers class * extends android.webkit.webViewClient {    public void *(android.webkit.WebView, java.lang.String, android.graphics.Bitmap);    public boolean *(android.webkit.WebView, java.lang.String);}-keepclassmembers class * extends android.webkit.webViewClient {    public void *(android.webkit.webView, jav.lang.String);}#4.2机子以上需加上以下代码,需添加 xx为包命-keepclassmembers class cn.xx.xx.Activity$AppAndroid {  public *;}-keepattributes *Annotation*-keepattributes *JavascriptInterface*#Glide-keep public class * implements com.bumptech.glide.module.GlideModule-keep public class * extends com.bumptech.glide.AppGlideModule-keep public enum com.bumptech.glide.load.resource.bitmap.ImageHeaderParser$** {  **[] $VALUES;  public *;}#okhttp-dontwarn okhttp3.**-dontwarn okio.**-dontwarn javax.annotation.**#极光推送混淆-dontoptimize-dontpreverify-dontwarn cn.jpush.**-keep class cn.jpush.** { *; }-keep class * extends cn.jpush.android.helpers.JPushMessageReceiver { *; }-dontwarn cn.jiguang.**-keep class cn.jiguang.** { *; }
其他一些三方库按文档添加

5.一些名词与符号的解释



结合模板理解:



6.参考文章

Android 混淆从入门到精通

Android 混淆解析

写在最后微信扫码提问


更多相关文章

  1. 没有一行代码,「2020 新冠肺炎记忆」这个项目却登上了 GitHub 中
  2. Android应用在不同版本间兼容性处理
  3. 史上最详细创建 Android(安卓)AIDL 远程服务步骤
  4. [置顶] Android与H5交互(混合开发)
  5. Android中的状态机(续)
  6. Android(安卓)Socket 通信实例...【Pnoker】
  7. Android中AVD的使用以及错误处理方法
  8. Android(安卓)上传图片到 Asp.Net 服务器的问题
  9. Nexus6 Android原生系统刷机方法

随机推荐

  1. opencv实时视频帧在android中没有显示sob
  2. 通过数据库接口获取到的中文数据是问号怎
  3. 尽管在清单文件中指定了权限,但是ACCESS_F
  4. Android快速开发框架andbase
  5. Android开发一些实用的类、方法及接口(新
  6. Android 监听各个Acitivity的生命周期
  7. viewpager 分页请求数据库并展示
  8. 现在做Android开发比较好?还是Android测试
  9. 在填充ListView时更改ImageView源
  10. 更改Edittext光标的颜色与粗细