apk反编译和AS基本混淆规则
2017-12-22 17:57
351 查看
一.反编译
用压缩包管理软件(如WinRAR、WinZIP等)解压apk得到classes.dex文件,把该文件放到dex2jar文件夹里。用dex2jar工具软件得到相应的jar文件。
(1)打开命令行界面。
(2)定位到dex2jar.bat所在目录。
(3)输入命令dex2jar.bat classes.dex即可生成jar文件(classes_dex2jar.jar)。
用jd-gui工具软件打开jar文件,就可查看源码。
二.基本混淆规则
as加入混淆规则之后对于代码的安全性就有了很大程度的提高了,首先需要允许打包时混淆,在build.gradle中修改下面的代码:buildTypes { release { // 打包时是否混淆 默认为false minifyEnabled true proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' } }
允许混淆之后就要加入我们的混淆规则了,在proguard-rules.pro文件中加入即可,注意:依赖库是不需要打开混淆的。
# 代码混淆压缩比,在0~7之间,默认为5,一般不做修改 -optimizationpasses 5 # 混合时不使用大小写混合,混合后的类名为小写 -dontusemixedcaseclassnames # 指定不去忽略非公共库的类 -dontskipnonpubliclibraryclasses # 这句话能够使我们的项目混淆后产生映射文件 # 包含有类名->混淆后类名的映射关系 -verbose # 指定不去忽略非公共库的类成员 -dontskipnonpubliclibraryclassmembers # 不做预校验,preverify是proguard的四个步骤之一,Android不需要preverify,去掉这一步能够加快混淆速度。 -dontpreverify # 保留Annotation不混淆 -keepattributes *Annotation*,InnerClasses # 避免混淆泛型 -keepattributes Signature # 抛出异常时保留代码行号 -keepattributes SourceFile,LineNumberTable # 指定混淆是采用的算法,后面的参数是一个过滤器 # 这个过滤器是谷歌推荐的算法,一般不做更改 -optimizations !code/simplification/cast,!field/*,!class/merging/* ############################################# # # Android开发中一些需要保留的公共部分 # ############################################# # 保留我们使用的四大组件,自定义的Application等等这些类不被混淆 # 因为这些子类都有可能被外部调用 -keep public class * extends android.app.Activity -keep public class * extends android.app.Appliction -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 # 保留support下的所有类及其内部类 -keep class android.support.** {*;} # 保留继承的 -keep public class * extends android.support.v4.** -keep public class * extends android.support.v7.** -keep public class * extends android.support.annotation.** # 保留R下面的资源 -keep class **.R$* {*;} # 保留本地native方法不被混淆 -keepclasseswithmembernames class * { native <methods>; } # 保留在Activity中的方法参数是view的方法, # 这样以来我们在layout中写的onClick就不会被影响 -keepclassmembers class * extends android.app.Activity{ public void *(android.view.View); } # 保留枚举类不被混淆 -keepclassmembers enum * { public static **[] values(); public static b2d7 ** 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; !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); } # webView处理,项目中没有使用到webView忽略即可 -keepclassmembers class fqcn.of.javascript.interface.for.webview { public *; } -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, jav.lang.String); } -ignorewarnings -keep class * { public private *; }
这是一些基本的混淆规则,项目中使用了第三方框架的话就去官网查看混淆规则,复制过来就可以了。反编译的方法借鉴于 原氢CSDN博客。欢迎大家来我 github+jekyll搭建的个人博客共同学习。
相关文章推荐
- Android apk反编译及AS代码混淆方法
- OSX(10.10.4 ) 反编译APK 和 混淆
- Android Apk的反编译与代码混淆
- 反编译apk、混淆、Proguard机制
- 项目清空在模拟器的缓存;代码混淆导出apk(绑定keystore);反编译
- apk的打包和反编译一、代码混淆ProGuard
- 反编译Apk得到JAVA层代码(混淆的话就惨了)
- Android APK安全: 代码混淆且加壳防止反编译
- 安卓APK反编译与混淆编译
- 反编译安卓apk基本步骤
- [置顶] Android开发之反编译、apk重新打包、apk混淆、apk对齐与不对齐、jar混淆、proguard
- Android混淆打包和APK反编译
- Android代码混淆防止反编译APK获取源码
- Android APK反编译以及代码混淆
- APK的混淆与反编译
- android学习笔记-Android如何防止apk程序被反编译代码混淆
- APK签名、混淆基本配置、打包以及常见问题
- AndroidAPK混淆打包以及反编译技巧
- Android反编译(未混淆的apk)
- android apk 导出(签名) is not translated in xx 代码混淆 反编译