android 混淆文件的编写(proguard-rules.pro)

本文详细介绍了ProGuard配置的各项参数,包括优化选项、警告处理、类成员保护等,并提供了具体应用场景,如保持特定方法、类不被混淆,排除日志记录等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

-optimizationpasses 5
-dontusemixedcaseclassnames
-dontskipnonpubliclibraryclasses
-dontpreverify
-verbose
-dontwarn
-dontskipnonpubliclibraryclassmembers
-ignorewarnings
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*


 -keepattributes Exceptions,InnerClasses,Signature,Deprecated,SourceFile,LineNumberTable,*Annotation*,EnclosingMethod

# 保持 native 方法不被混淆
-keepclasseswithmembernames class * {
    native <methods>;
}
-keepclasseswithmembers class * {
    public <init>(android.content.Context, android.util.AttributeSet);
}
-keepclasseswithmembers class * {
    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;
    !static !transient <fields>;
    !private <fields>;
    !private <methods>;
    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);
}


#保持第三方包不混淆
-dontwarn com.tencent.**
-keep class com.tencent.**{*;}
-keep class com.qq.**{*;}
-keep class tencent.tls.**{*;}
#保持指定包下的类不混淆
-keep class nodepp.**{*;}
-keep public class com.nodepp.smartnode.helper.**{*;}
-keep public class com.nodepp.smartnode.helper.**{*;}
-keep public class com.nodepp.smartnode.model.**{*;}
-keep public class com.nodepp.smartnode.callback.**{*;}

#移除log日志,需要把sdk\tools\proguard目录下的proguard-android.txt文件下的-dontoptimize注释掉才能生效
-assumenosideeffects class android.util.Log {
public static boolean isLoggable(java.lang.String, int);
public static int v(...);
public static int i(...);
public static int w(...);
public static int d(...);
public static int e(...);
}

android {
    compileSdkVersion 22
    buildToolsVersion '22.0.1'

    defaultConfig {
        minSdkVersion 15
        targetSdkVersion 22
        versionCode 1
        versionName "1.0"
    }
    buildTypes {
        release {
            minifyEnabled false //false表示不混淆,true表示开启混淆
            //Zipalign优化
            zipAlignEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
        debug {
            minifyEnabled false    //false表示不混淆,true表示开启混淆

            //Zipalign优化
            zipAlignEnabled true
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }
    lintOptions {
        abortOnError false
    }
}

打包jar 的话直接在命令行输入gradlew makejar就行,在module下的gradle.build进行配置,混淆文件也是module下的
打包apk进行混淆时直接build整个工程,在app下的gradle.build进行配置,
混淆文件也是app下的
### ProGuard 规则配置以确保 AAR 库中包含 meta-data 为了确保在生成 AAR 库时通过 ProGuard 规则保留 `meta-data`,需要仔细编写 ProGuard 文件 (`proguard-rules.pro`) 中的相关规则。以下是最佳实践和具体方法: #### 保持 AndroidManifest.xml 的 Meta 数据不被混淆或移除 当构建 AAR 库时,如果库中有自定义的组件(如广播接收器、服务等),这些组件可能依赖于 `AndroidManifest.xml` 中声明的 `<meta-data>` 字段。因此,必须防止 ProGuard 移除或修改这些元数据。 ```text -keep public class * extends android.app.Activity { <init>(...); public void onCreate(...); } -keepattributes Activity,ActivityAlias,ReceiverAction,Service,Provider,\ UsesLibrary,MimeType,MetaData,Permission,UsesPermission\ ,Instrumentation,IntentFilter,GrantUriPermissions,Alias -keepclassmembers class * { @android.annotation.MetaData <fields>; } ``` 上述规则确保所有带有 `@MetaData` 注解的字段不会被混淆,并且会保留其原始名称[^1]。 #### 处理特定的 Meta Data 键值对 对于某些特殊的键值对,可以通过指定的方式保护它们免受混淆影响: ```text -keepnames class com.example.yourpackage.YourClass { static final java.lang.String YOUR_META_DATA_KEY; } ``` 此命令告诉 ProGuard 不要更改给定类中的静态字符串常量名,从而保证编译后的二进制文件能够正确解析对应的 `meta-data` 值。 #### 完整示例:ProGuard Rules File (proguard-rules.pro) 下面提供了一个完整的例子来展示如何设置 ProGuard 来处理 AAR 输出中的 `meta-data`: ```text # Keep all classes that extend from specific base classes. -keep public class * extends android.content.BroadcastReceiver -keep public class * extends android.app.Service -keep public class * extends android.app.Application -keep public class * extends androidx.fragment.app.Fragment # Preserve the manifest attributes and metadata entries. -keepattributes Manifest,Annotation,*Annotation*,InnerClasses,Signature,EnclosingMethod,Exceptions,SourceFile,LineNumberTable,LocalVariable*Table,*ParameterNames* # Prevent obfuscating or removing any field annotated with @Metadata. -keepclassmembers class * { @android.annotation.Metadata <fields>; } # Specific key-value pairs you want to keep as-is within your library's codebase. -keepnames class com.example.yourpackage.YourClass { static final java.lang.String META_DATA_EXAMPLE_KEY; } ``` 这段脚本不仅涵盖了基本的反混淆需求,还特别针对了 `meta-data` 的保存进行了强化。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值