proguar在Android混淆中的用法

混淆器通过删除从未用过的代码和使用晦涩名字重命名类、字段和方法,对代码进行压缩,优化和混淆。结果是一个比較小的.apk文件,该文件比較难进行逆向project。因此,当你的应用程序对安全敏感(要求高),比如当你授权应用程序的时候,混淆器是一种重要的保护手段。

proguard 基本语法

// 保留native方法的方法的方法名和包含native方法的类的类名不变

-keepclasseswithmembernames class {

  native<methods>;

}

// 保留继承与View的类中的set*和get*方法

-keepclassmembers public class * extends android.view.View {

  void set*(***);

  *** get*();

}

// 保留继承与Activity的类中以View为参数的方法

-keepclassmembers class * extends android.app.Activity {

  public void *(android.view.View);

}

// 保留实现了Parcelable 接口的类的类名以及实现了 Parcelanle$Creator 的内部类

-keep class * implemenets android.os.Parcelable {

  public static final android.os.Parcelanle$Creator *;

}

// 保留 R$*类中静态字段的字段名

-keep class **.R$* {

  public static <fields>;

}

也就是

类名不混淆 用keep

方法名不混淆 用keepclassmembers 或者 keepclasseswithmembernames(后者用于native不混淆)

不混淆的情况:

1 jni 调用java方法

2 四大组件

3 R文件

4 某些通过反射调用的类或方法

5 第三jar包(一般情况下不要混淆)

混淆去掉log

-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(...);

}

 assumenosideeffects,proguard 配置文件里的参数。assume no side effects;假定无效;该属性也就是标识无效代码。我们就是通过这个参数来让proguard删除日志代码。

以上是 proguar在Android混淆中的用法 的全部内容, 来源链接: utcz.com/z/342459.html

回到顶部