美文网首页
android 混淆

android 混淆

作者: 荞麦穗 | 来源:发表于2018-01-15 21:33 被阅读0次

    android代码混淆是提高app安全的一种手段,当然还有加固,这个暂且不提。要想混淆工程,首先要在gradle文件里开启混淆的设置开关

    buildTypes {
            release {
                minifyEnabled true//混淆开关
                proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
                signingConfig signingConfigs.release
            }
    }
    

    然后要在app/proguard-rules.pro文件里添加混淆规则。

    # If you keep the line number information, uncomment this to
    # hide the original source file name.
    #-renamesourcefileattribute SourceFile
    
    #-------------------------------------------定制化区域----------------------------------------------
    #---------------------------------1.实体类---------------------------------
    -keep class com.aliyunplayer.test.**{*;}
    -keep class com.Bean.**{*;}
    -keep class com.example.cxd.aliyunplayertest.**{*;}
    -keep class com.Utils.**{*;}
    
    #-------------------------------------------------------------------------
    
    #---------------------------------2.第三方包-------------------------------
    -keep class com.alivc.player.**{*;}
    -keep class com.aliyun.clientinforeport.**{*;}
    -keep class com.aliyun.vodplayer.**{*;}
    #Warning:com.squareup.picasso.OkHttpDownloader:can't find referenced class com.squareup.okhttp.OkHttpClient
    -keepattributes SourceFile,LineNumberTable
    -keep class com.parse.*{ *; }
    -dontwarn com.parse.**
    -dontwarn com.squareup.picasso.**
    -keepclasseswithmembernames class * {native <methods>; }
    -dontwarn org.codehaus.**
    -dontwarn java.nio.**
    -keep class org.codehaus.**{ *;}
    -keep class java.nio.**{ *;}
    
    #-------------------------------------------------------------------------
    
    #---------------------------------3.与js互相调用的类------------------------
    
    
    
    #-------------------------------------------------------------------------
    
    #---------------------------------4.反射相关的类和方法-----------------------
    
    
    
    #----------------------------------------------------------------------------
    #---------------------------------------------------------------------------------------------------
    
    #-------------------------------------------基本不用动区域--------------------------------------------
    #---------------------------------基本指令区----------------------------------
    -optimizationpasses 5  #代码混淆的压缩比例,值在0-7之间
    -dontskipnonpubliclibraryclassmembers #指定不忽略非公共库的类
    -printmapping proguardMapping.txt#生成混淆后类名的映射文件
    -optimizations !code/simplification/cast,!field/*,!class/merging/* #指定混淆是采用的算法
    -keepattributes *Annotation*,InnerClasses #不混淆Annotation
    -keepattributes Signature #不混淆泛型
    -keepattributes SourceFile,LineNumberTable #抛出异常时保留代码行号
    #----------------------------------------------------------------------------
    
    
    #---------------------------------默认保留区---------------------------------
    -keep public class * extends android.app.Activity
    -keep public class * extends android.app.Application
    -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
    -keep class android.support.** {*;}
    
    -keep public class * extends android.view.View{
        *** get*();
        void set*(***);
        public <init>(android.content.Context);
        public <init>(android.content.Context, android.util.AttributeSet);
        public <init>(android.content.Context, android.util.AttributeSet, int);
    }
    -keepclasseswithmembers class * {
        public <init>(android.content.Context, android.util.AttributeSet);
        public <init>(android.content.Context, android.util.AttributeSet, int);
    }
    -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();
    }
    -keep class **.R$* {
     *;
    }
    -keepclassmembers class * {
        void *(**On*Event);
    }
    #----------------------------------------------------------------------------
    
    
    
    #---------------------------------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);
    }
    #---------------------------------------------------------------------------------------------------
    

    这里有借鉴网上的一些混淆设置和规范。我觉的这样分块看起来很清晰。
    重点是混淆后打包总出错的问题。如:
    Error:(148) Error: "have_account" is not translated in "zh-CN" (Chinese: China) [MissingTranslation] Error:Execution failed for task ':app:lintVitalRelease'.
    这个错误是字符串适配的问题,可以选择忽略她。方式为:

      android {
          lintOptions {
              checkReleaseBuilds false
              // Or, if you prefer, you can continue to check for errors in release builds,
              // but continue the build even when errors are found:
              abortOnError false
          }
      }
    

    还有就是找不到一些类。就像Warning:can't find referenced class问题还有缺少了某个库,可以试试使用-ignorewarnings或者-dontwarn选项!-dontwarn我试过了,加上-dontwarn com.xxx.bbbb.** 之后确实没有报错,可以打包出来了,但是运行一下试试看?如果运气好的话,程序没有执行到找不到的类那里就不会报错,如果运气不好的话执行到那里了就会抛ClassNotFoundException!这只是治标不治本的方式。
    可以使用
    -dontwarn com.xx.bbb.**
    -keep class com.xx.bbb.** { *;}
    参数来保持第三方库中的类而不乱,-dontwarn和-keep 结合使用,意思是保持com.xx.bbb.**这个包里面的所有类和所有方法而不混淆,接着还叫ProGuard不要警告找不到com.xx.bbb.**这个包里面的类的相关引用。
    引用:http://blog.csdn.net/u_xtian/article/details/7495023

    相关文章

      网友评论

          本文标题:android 混淆

          本文链接:https://www.haomeiwen.com/subject/zazdoxtx.html