Androidによって開発されたProGuardテクノロジー

この記事は主に「AppR&D Records」という本に言及していますが、困っている友人はこの本を参照して詳細を知ることができます。

ProGuardの概要

ProGuardには、合計で次の4つの関数が含まれ、それぞれがオプションです。構成スクリプトを使用して実行する関数を決定できます。ProGuardの実行フローを次の図に示します。

  • 縮小:コード内の不要なクラス、フィールド、メソッド、および属性を検出して削除します。
  • 最適化:バイトコードを最適化し、不要な命令を削除します。
  • 難読化:クラス、フィールド、メソッドの名前を変更するには、a、b、c、dなどの短くて意味のない名前を使用します。
  • 事前チェック(Preveirfy):Javaプラットフォームで処理されたコードを事前チェックします。

ここに画像の説明を挿入

ProGuardの難読化ルール

以下は、混乱を招くための最も基本的な構成情報です。どのアプリでもこれを使用する必要があり、テンプレートとして使用できます。

1.基本的な手順

  # 代码混淆压缩比,在07之间,默认为5,一般不需要改
    -optimizationpasses 5

 # 混淆时不使用大小写混合,混淆后的类名为小写,Windows操作系统必须加这一条,因为Windows系统对大小写不敏感
   -dontusemixedcaseclassnames

 # 指定不去忽略非公共的库的类
-dontskipnonpubliclibraryclasses

# 指定不去忽略非公共的库的类的成员
-dontskipnonpubliclibraryclassmembers

# 不做预校验,preverify是proguard的4个步骤之一
# Android不需要preverify,去掉这一步可加快混淆速度
-dontpreverify

# 有了verbose这句话,混淆后就会生成映射文件
# 包含有类名->混淆后类名的映射关系
# 然后使用printmapping指定映射文件的名称
-verbose
-printmapping proguardMapping.txt

# 指定混淆时采用的算法,后面的参数是一个过滤器
# 这个过滤器是谷歌推荐的算法,一般不改变
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

# 保护代码中的Annotation不被混淆,这在JSON实体映射时非常重要,比如fastJson
-keepattributes *Annotation*

# 避免混淆泛型,这在JSON实体映射时非常重要,比如fastJson
-keepattributes Signature

//抛出异常时保留代码行号
-keepattributes SourceFile,LineNumberTable

2.守るべきこと

以下はほんの一例です。必要に応じて必要なものを追加できます。

# 保留所有的本地native方法不被混淆

-keepclasseswithmembernames class * {
    
    
    native <methods>;
}

# 保留了继承自Activity、Application这些类的子类
# 因为这些子类,都有可能被外部调用
# 比如说,第一行就保证了所有Activity的子类不要被混淆

-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
 
# 保留在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 <init>(android.content.Context);
    public <init>(android.content.Context, android.util.AttributeSet);
    public <init>(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;
    private void writeObject(java.io.ObjectOutputStream);
    private void readObject(java.io.ObjectInputStream);
    java.lang.Object writeReplace();
    java.lang.Object readResolve();
}

# 对于R(资源)下的所有类及其方法,都不能被混淆
//$表示的是内嵌类,内嵌类经常会被混淆,结果在调用的时候为空就会导致崩溃,最好的解决方法是把这个内嵌类拿出来,单独成为一个类。如果一定要内置,那么这个类就必须在混淆时进行保留。
-keep class **.R$* {
    
    
    *;
}

# 对于带有回调函数onXXEvent的,不能被混淆

-keepclassmembers class * {
    
    
    void *(**On*Event);
}

# 保留实体类和成员不被混淆

-keep public class com.youndheart.entity.** {
    
    

    public void set*(***);
    public *** get*();
    public *** is*();
}

3.WebViewの処理

# 对WebView的处理

-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, java.lang.String)

}

#在app中与HTML5的JavaScript的交互进行特殊处理
#我们需要确保这些js要调用的原生方法不能够被混淆,于是我们需要做如下处理:
-keepclassmembers class com.ljd.example.JSInterface {
    
    
    <methods>;
}

4.サードパーティのJarパッケージのソリューション

  • android-support-v4.jarのソリューション
-libraryjars libs/android-support-v4.jar

-dontwarn android.support.v4.**

-keep class android.support.v4.**  {
    
     *; }

-keep interface android.support.v4.app.** {
    
     *; }

-keep public class * extends android.support.v4.**

-keep public class * extends android.app.Fragment
  • 他のサードパーティjarパッケージのソリューション
    一般的に、サードパーティjarパッケージはprogiardによって難読化されており、通常、SDKドキュメントに関連する手順があります。これらのSDKクラスとメソッドを回避する必要があります。アプリ。

関連参照リンク:https://www.jianshu.com/p/b5b2a5dfaaf4
https://blog.csdn.net/pang9998/article/details/83505980

おすすめ

転載: blog.csdn.net/qq_36828822/article/details/105897367