proguard-android.txt注释

# This is a configuration file for ProGuard.
# http://proguard.sourceforge.net/index.html#manual/usage.html
#
# Starting with version 2.2 of the Android plugin for Gradle, these files are no longer used. Newer
# versions are distributed with the plugin and unpacked at build time. Files in this directory are
# no longer maintained.


# mayq:以下中文注释都是我加的;
# 混淆后的名字不要同时使用大小写字母,如果你得到了一个jar,里面包含a和A,然后当你在windows这种大小写不敏感的系统上解压的时候,a和A就会覆盖;
-dontusemixedcaseclassnames
# 一般情况下library里的非public类不会被外部引用,跳过他们能加速混淆过程;
# 但是如果library里有个非public的类C被外部继承了,而这个C在外部代码里被改写后,就找不到引用了;
-dontskipnonpubliclibraryclasses
# 输出混淆过程中的详细信息;
-verbose


# Optimization is turned off by default. Dex does not like code run
# through the ProGuard optimize and preverify steps (and performs some
# of these optimizations on its own).
# 关闭proguard的优化和预检功能,Dex后续会负责这些优化工作;
-dontoptimize
#什么是预检?class loader在加载class文件的时候会对byte code进行检查,确保代码不会对jvm造成危害;
#proguard也可以预检,并将预检信息加入class文件,于是,当class loader加载class的时候,就能加快速度和减少内存使用量了;
-dontpreverify
# Note that if you want to enable optimization, you cannot just
# include optimization flags in your own project configuration file;
# instead you will need to point to the
# "proguard-android-optimize.txt" file instead of this one from your
# project.properties file.
# 保留注释,这个看似是个通配符,其实不是,是保留所有的注释,不管这个注释叫什么;
-keepattributes *Annotation*


# 暂时只知道和App发布到谷歌商店的时候设置授权有关系
-keep public class com.google.vending.licensing.ILicensingService
-dontnote com.google.vending.licensing.ILicensingService




# For native methods, see http://proguard.sourceforge.net/manual/examples.html#native
# 不要重命名包含native方法的类和方法;
-keepclasseswithmembernames class * {
    native <methods>;
}


# Keep setters in Views so that animations can still work.
# Setters for listeners can still be removed.
# see http://proguard.sourceforge.net/manual/examples.html#beans
# 保留View的子类的这些setter和getter方法,动画系统会调用;
-keepclassmembers public class * extends android.view.View {
    void set*(%);
    void set*(%, %);
    void set*(%, %, %, %);
    void set*(%[]);
    void set*(**[]);
    void set*(!**Listener);


    % get*();
    %[] get*();
    **[] get*();
    !**Listener get*();
}


# We want to keep methods in Activity that could be used in the XML attribute onClick.
# 保留Activity里被layout里的onClick属性引用的方法;
-keepclassmembers class * extends android.app.Activity {
    public void *(android.view.View);
}


# For enumeration classes, see http://proguard.sourceforge.net/manual/examples.html#enumerations
# 保留枚举类的values和valueOf方法;java编译器会把enum转成具有特殊结构的class,jvm是通过反射调用这个类的values()和valueOf()方法的;
-keepclassmembers enum * {
    public static **[] values();
    public static ** valueOf(java.lang.String);
}


# 保留Parcelable对象的static CREATOR域,这是Android用来反序列化对象的.由于CREATOR是在运行时被调用,所以如果不加规则,ProGuard会把它当成无用的成员直接去掉.
-keepclassmembers class * implements android.os.Parcelable {
    public static final ** CREATOR;
}


# 保留R的内部类的public static域,app可能通过反射使用这些域;
-keepclassmembers class **.R$* {
    public static <fields>;
}


# The support libraries contains references to newer platform versions.
# Don't warn about those in case this app is linking against an older
# platform version. We know about them, and they are safe.
# 支持库包含了对新版本platform的引用,在和旧的platform链接的时候会报错,我们心里有数,不要输出通知和警告;
-dontnote android.support.**
-dontwarn android.support.**


# Understand the @Keep support annotation.
# 不要混淆Keep注释类,这个注释可能被用来修饰某些类,表示不要混淆;
# 所以说,我们有2个途径实现不要混淆:1)proguard配置文件; 2)在java代码里使用@Keep注释;
-keep class android.support.annotation.Keep


# 不要混淆由@Keep注释的类,包括所有成员和方法;
-keep @android.support.annotation.Keep class * {*;}


# 不要混淆由@Keep注释的方法及其所在的类;
-keepclasseswithmembers class * {
    @android.support.annotation.Keep <methods>;
}


# 不要混淆由@Keep注释的域及其所在的类;
-keepclasseswithmembers class * {
    @android.support.annotation.Keep <fields>;
}


# 不要混淆由@Keep注释的构造方法及其所在的类;
-keepclasseswithmembers class * {
    @android.support.annotation.Keep <init>(...);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ProGuard是一个混淆、压缩和优化Java字节码的工具。它是一个开源的项目,由Guardian Digital公司开发和维护。proguard-base-7.2.2是最新版本,于2020年5月发布。 ProGuard主要用于缩减应用程序的大小,提高应用程序的性能和安全性。在Android应用程序开发中,ProGuard被广泛应用于将Java源代码转换为Dalvik可执行文件时,缩小APK包的大小。 ProGuard能够识别和删除无用的类、字段、方法和属性,以及优化和简化代码,减少字节码的大小和复杂度。此外,ProGuard还能够将代码进行混淆,使得反向工程变得困难,提高应用程序的安全性。 ProGuard提供了一系列选项,使得开发人员可以灵活地选择需要进行的操作。比如,可以选择是否进行代码混淆、删除无用的类和字段、优化字节码、压缩类文件等。开发人员可以通过修改ProGuard的配置文件来配置ProGuard的选项。 总之,ProGuard是一个非常实用的工具,能够帮助开发人员优化和缩小应用程序的大小,并提高应用程序的安全性和性能。proguard-base-7.2.2作为最新版本,还提供了更加完善的功能和更好的性能。 ### 回答2: proguard-base-7.2.2是一个代码混淆工具,用于保护Android应用程序的源代码不被反编译。它可以压缩、优化和混淆代码,从而使得反编译出来的代码难以阅读和理解。它可以对Java类、接口、方法、字段和注释进行混淆,并且可以对资源文件进行重命名和删除。除此之外,它还可以进行优化,如移除不必要的代码和字节码优化,以减少应用程序的体积和提升运行速度。 proguard-base-7.2.2支持Android Studio和Gradle构建系统,并且可以集成到Android开发环境中。使用它需要在项目的构建过程中进行配置,参数设置等。另外还需注意,混淆过程中也有一定的风险,例如因错误的混淆而导致应用程序崩溃等。因此,建议在使用之前对其进行测试和备份代码,以避免出现不必要的损失。 总之,proguard-base-7.2.2是一个非常实用的Android开发工具,可以保护应用程序的代码不被反编译,提高应用程序的安全性,同时可以优化和压缩代码,优化应用程序的性能。 ### 回答3: Proguard是一个Java字节码混淆器,它可以将已编译的Java代码进行优化,压缩和混淆混淆是指将代码中的变量,方法名等改为随机的名称,使得逆向分析非常困难。压缩是指将代码中的无用部分去除,以减小APK的体积。优化则是对Java代码进行一些优化,使得运行更加快速。 Proguard可以用于Android应用的混淆和优化,可以提高代码安全性和应用性能。Proguard基于配置文件进行设置,用户可以根据自己的需求对其中的参数进行调整,以达到最佳的混淆效果。Proguard还提供了可以优化和预校验代码的工具,以帮助开发者在编译期捕获代码中潜在的错误。 Proguard基于Java字节码的操作,适用于所有使用Java语言编写的Android应用。使用Proguard可以防止一些常见的攻击,比如代码混淆、反编译、应用程序解析等。Proguard可以帮助开发者实现最高的安全性,对于需要保护机密信息和使用敏感数据的应用非常有用。但是Proguard并不能完全避免所有类型的逆向工程攻击。 Proguard-base-7.2.2是Proguard的一个版本,该版本为最新版本,提供了更好的性能和更好的混淆效果。使用Proguard可以有效地保护Android应用的安全性,减少恶意攻击的可能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值