经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » Android » 查看文章
Android 一些常用的混淆Proguard
来源:jb51  时间:2021/2/18 16:18:31  对本文有异议

一些公共的模板

  1. #############################################
  2. #
  3. # 对于一些基本指令的添加
  4. #
  5. #############################################
  6. # 代码混淆压缩比,在 0~7 之间,默认为 5,一般不做修改
  7. -optimizationpasses 5
  8.  
  9. # 混合时不使用大小写混合,混合后的类名为小写
  10. -dontusemixedcaseclassnames
  11.  
  12. # 指定不去忽略非公共库的类
  13. -dontskipnonpubliclibraryclasses
  14.  
  15. # 这句话能够使我们的项目混淆后产生映射文件
  16. # 包含有类名->混淆后类名的映射关系
  17. -verbose
  18.  
  19. # 指定不去忽略非公共库的类成员
  20. -dontskipnonpubliclibraryclassmembers
  21.  
  22. # 不做预校验,preverify 是 proguard 的四个步骤之一,Android 不需要 preverify,去掉这一步能够加快混淆速度。
  23. -dontpreverify
  24.  
  25. # 保留 Annotation 不混淆
  26. -keepattributes *Annotation*,InnerClasses
  27.  
  28. # 避免混淆泛型
  29. -keepattributes Signature
  30.  
  31. # 抛出异常时保留代码行号
  32. -keepattributes SourceFile,LineNumberTable
  33.  
  34. # 指定混淆是采用的算法,后面的参数是一个过滤器
  35. # 这个过滤器是谷歌推荐的算法,一般不做更改
  36. -optimizations !code/simplification/cast,!field/*,!class/merging/*
  37.  
  38.  
  39. #############################################
  40. #
  41. # Android开发中一些需要保留的公共部分
  42. #
  43. #############################################
  44.  
  45. # 保留我们使用的四大组件,自定义的 Application 等等这些类不被混淆
  46. # 因为这些子类都有可能被外部调用
  47. -keep public class * extends android.app.Activity
  48. -keep public class * extends android.app.Appliction
  49. -keep public class * extends android.app.Service
  50. -keep public class * extends android.content.BroadcastReceiver
  51. -keep public class * extends android.content.ContentProvider
  52. -keep public class * extends android.app.backup.BackupAgentHelper
  53. -keep public class * extends android.preference.Preference
  54. -keep public class * extends android.view.View
  55. -keep public class com.android.vending.licensing.ILicensingService
  56.  
  57.  
  58. # 保留 support 下的所有类及其内部类
  59. -keep class android.support.** { *; }
  60.  
  61. # 保留继承的
  62. -keep public class * extends android.support.v4.**
  63. -keep public class * extends android.support.v7.**
  64. -keep public class * extends android.support.annotation.**
  65.  
  66. # 保留 R 下面的资源
  67. -keep class **.R$* { *; }
  68.  
  69. # 保留本地 native 方法不被混淆
  70. -keepclasseswithmembernames class * {
  71. native <methods>;
  72. }
  73.  
  74. # 保留在 Activity 中的方法参数是view的方法,
  75. # 这样以来我们在 layout 中写的 onClick 就不会被影响
  76. -keepclassmembers class * extends android.app.Activity {
  77. public void *(android.view.View);
  78. }
  79.  
  80. # 保留枚举类不被混淆
  81. -keepclassmembers enum * {
  82. public static **[] values();
  83. public static ** valueOf(java.lang.String);
  84. }
  85.  
  86. # 保留我们自定义控件(继承自 View)不被混淆
  87. -keep public class * extends android.view.View {
  88. *** get*();
  89. void set*(***);
  90. public <init>(android.content.Context);
  91. public <init>(android.content.Context, android.util.AttributeSet);
  92. public <init>(android.content.Context, android.util.AttributeSet, int);
  93. }
  94.  
  95. # 保留 Parcelable 序列化类不被混淆
  96. -keep class * implements android.os.Parcelable {
  97. public static final android.os.Parcelable$Creator *;
  98. }
  99.  
  100. # 保留 Serializable 序列化的类不被混淆
  101. -keepnames class * implements java.io.Serializable
  102. -keepclassmembers class * implements java.io.Serializable {
  103. static final long serialVersionUID;
  104. private static final java.io.ObjectStreamField[] serialPersistentFields;
  105. !static !transient <fields>;
  106. !private <fields>;
  107. !private <methods>;
  108. private void writeObject(java.io.ObjectOutputStream);
  109. private void readObject(java.io.ObjectInputStream);
  110. java.lang.Object writeReplace();
  111. java.lang.Object readResolve();
  112. }
  113.  
  114. # 对于带有回调函数的 onXXEvent、**On*Listener 的,不能被混淆
  115. -keepclassmembers class * {
  116. void *(**On*Event);
  117. void *(**On*Listener);
  118. }
  119.  
  120. # webView 处理,项目中没有使用到 webView 忽略即可
  121. -keepclassmembers class fqcn.of.javascript.interface.for.webview {
  122. public *;
  123. }
  124. -keepclassmembers class * extends android.webkit.webViewClient {
  125. public void *(android.webkit.WebView, java.lang.String, android.graphics.Bitmap);
  126. public boolean *(android.webkit.WebView, java.lang.String);
  127. }
  128. -keepclassmembers class * extends android.webkit.webViewClient {
  129. public void *(android.webkit.webView, java.lang.String);
  130. }
  131.  
  132. # js
  133. -keepattributes JavascriptInterface
  134. -keep class android.webkit.JavascriptInterface { *; }
  135. -keepclassmembers class * {
  136. @android.webkit.JavascriptInterface <methods>;
  137. }
  138.  
  139. # @Keep
  140. -keep,allowobfuscation @interface android.support.annotation.Keep
  141. -keep @android.support.annotation.Keep class *
  142. -keepclassmembers class * {
  143. @android.support.annotation.Keep *;
  144. }
  145.  

一些自定义的模板

  1. # 通配符*,匹配任意长度字符,但不含包名分隔符(.)
  2. # 通配符**,匹配任意长度字符,并且包含包名分隔符(.)
  3.  
  4. # 不混淆某个类
  5. -keep public class com.jasonwu.demo.Test { *; }
  6.  
  7. # 不混淆某个包所有的类
  8. -keep class com.jasonwu.demo.test.** { *; }
  9.  
  10. # 不混淆某个类的子类
  11. -keep public class * com.jasonwu.demo.Test { *; }
  12.  
  13. # 不混淆所有类名中包含了 ``model`` 的类及其成员
  14. -keep public class **.*model*.** {*;}
  15.  
  16. # 不混淆某个接口的实现
  17. -keep class * implements com.jasonwu.demo.TestInterface { *; }
  18.  
  19. # 不混淆某个类的构造方法
  20. -keepclassmembers class com.jasonwu.demo.Test {
  21. public <init>();
  22. }
  23.  
  24. # 不混淆某个类的特定的方法
  25. -keepclassmembers class com.jasonwu.demo.Test {
  26. public void test(java.lang.String);
  27. }

aar中增加独立的混淆配置

  1. android {
  2. ···
  3. defaultConfig {
  4. ···
  5. consumerProguardFile 'proguard-rules.pro'
  6. }
  7. ···
  8. }

检查混淆和追踪异常

开启 Proguard 功能,则每次构建时 ProGuard 都会输出下列文件:

dump.txt 说明 APK 中所有类文件的内部结构。

mapping.txt 提供原始与混淆过的类、方法和字段名称之间的转换。

seeds.txt 列出未进行混淆的类和成员。

usage.txt 列出从 APK 移除的代码。

这些文件保存在 /build/outputs/mapping/release/ 中。我们可以查看 seeds.txt 里面是否是我们需要保留的,以及 usage.txt 里查看是否有误删除的代码。 mapping.txt 文件很重要,由于我们的部分代码是经过重命名的,如果该部分出现 bug,对应的异常堆栈信息里的类或成员也是经过重命名的,难以定位问题。我们可以用 retrace 脚本(在 Windows 上为 retrace.bat;在 Mac/Linux 上为 retrace.sh)。它位于 /tools/proguard/ 目录中。该脚本利用 mapping.txt 文件和你的异常堆栈文件生成没有经过混淆的异常堆栈文件,这样就可以看清是哪里出问题了。使用 retrace 工具的语法如下:

  1. retrace.bat|retrace.sh [-verbose] mapping.txt [<stacktrace_file>]

检查混淆和追踪异常

开启 Proguard 功能,则每次构建时 ProGuard 都会输出下列文件:

dump.txt 说明 APK 中所有类文件的内部结构。

mapping.txt 提供原始与混淆过的类、方法和字段名称之间的转换。

seeds.txt 列出未进行混淆的类和成员。

usage.txt 列出从 APK 移除的代码。

这些文件保存在 /build/outputs/mapping/release/ 中。我们可以查看 seeds.txt 里面是否是我们需要保留的,以及 usage.txt 里查看是否有误删除的代码。 mapping.txt 文件很重要,由于我们的部分代码是经过重命名的,如果该部分出现 bug,对应的异常堆栈信息里的类或成员也是经过重命名的,难以定位问题。我们可以用 retrace 脚本(在 Windows 上为 retrace.bat;在 Mac/Linux 上为 retrace.sh)。它位于 /tools/proguard/ 目录中。该脚本利用 mapping.txt 文件和你的异常堆栈文件生成没有经过混淆的异常堆栈文件,这样就可以看清是哪里出问题了。使用 retrace 工具的语法如下:

  1. retrace.bat|retrace.sh [-verbose] mapping.txt [<stacktrace_file>]

结语

以上就是简单介绍了Android中常用混淆的问题,还有很多不足的东西欢迎大家补充 祝大家新年快乐,技术越来越好,fighting

以上就是Android 一些常用的混淆Proguard的详细内容,更多关于Android 常用的混淆Proguard的资料请关注w3xue其它相关文章!

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号