Android studio 使用心得(五)---代碼混淆和破解apk

   版權聲明:本文出自veidy的博客,轉載必須註明出處  java

    轉載請註明出處http://my.oschina.net/aibenben/blog/371889 android

 

這篇文章等是跟你們分享一在Android studio 進行代碼混淆配置。以前你們在eclipse上也弄過代碼混淆配置,其實同樣,你們能夠把以前在eclipse上的配置文件直接拿過來用。無論是.cfg文件仍是proguard-rules.pro文件都同樣。 web

先給你們貼一個混淆模板吧。註釋很清楚。是我目前一個項目用的proguard.cfg配置文件 算法

#指定代碼的壓縮級別
-optimizationpasses 5

#包明不混合大小寫
-dontusemixedcaseclassnames

#不去忽略非公共的庫類
-dontskipnonpubliclibraryclasses

 #優化  不優化輸入的類文件
-dontoptimize

 #預校驗
-dontpreverify

 #混淆時是否記錄日誌
-verbose

 # 混淆時所採用的算法
-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*

#保護註解
-keepattributes *Annotation*

# 保持哪些類不被混淆
-keep public class * extends android.app.Fragment
-keep public class * extends android.app.Activity
-keep public class * extends android.app.Application
-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 com.android.vending.licensing.ILicensingService
#若是有引用v4包能夠添加下面這行
-keep public class * extends android.support.v4.app.Fragment




#忽略警告
-ignorewarning

#####################記錄生成的日誌數據,gradle build時在本項目根目錄輸出################

#apk 包內全部 class 的內部結構
-dump class_files.txt
#未混淆的類和成員
-printseeds seeds.txt
#列出從 apk 中刪除的代碼
-printusage unused.txt
#混淆先後的映射
-printmapping mapping.txt

#####################記錄生成的日誌數據,gradle build時 在本項目根目錄輸出-end################


################混淆保護本身項目的部分代碼以及引用的第三方jar包library#########################
#-libraryjars libs/umeng-analytics-v5.2.4.jar
#-libraryjars libs/alipaysdk.jar
#-libraryjars libs/alipaysecsdk.jar
#-libraryjars libs/alipayutdid.jar
#-libraryjars libs/wup-1.0.0-SNAPSHOT.jar
#-libraryjars libs/weibosdkcore.jar


#三星應用市場須要添加:sdk-v1.0.0.jar,look-v1.0.1.jar
#-libraryjars libs/sdk-v1.0.0.jar
#-libraryjars libs/look-v1.0.1.jar

#我是以libaray的形式引用了一個圖片加載框架,若是不想混淆 keep 掉
-keep class com.nostra13.universalimageloader.** { *; }

#友盟
-keep class com.umeng.**{*;}

#支付寶
-keep class com.alipay.android.app.IAliPay{*;}
-keep class com.alipay.android.app.IAlixPay{*;}
-keep class com.alipay.android.app.IRemoteServiceCallback{*;}
-keep class com.alipay.android.app.lib.ResourceMap{*;}


#信鴿推送
-keep class com.tencent.android.tpush.**  {* ;}
-keep class com.tencent.mid.**  {* ;}


#本身項目特殊處理代碼

#忽略警告
-dontwarn com.veidy.mobile.common.**
#保留一個完整的包
-keep class com.veidy.mobile.common.** {
    *;
 }

-keep class  com.veidy.activity.login.WebLoginActivity{*;}
-keep class  com.veidy.activity.UserInfoFragment{*;}
-keep class  com.veidy.activity.HomeFragmentActivity{*;}
-keep class  com.veidy.activity.CityActivity{*;}
-keep class  com.veidy.activity.ClinikActivity{*;}

#若是引用了v4或者v7包
-dontwarn android.support.**

############混淆保護本身項目的部分代碼以及引用的第三方jar包library-end##################

-keep public class * extends android.view.View {
    public <init>(android.content.Context);
    public <init>(android.content.Context, android.util.AttributeSet);
    public <init>(android.content.Context, android.util.AttributeSet, int);
    public void set*(...);
}

#保持 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);
}
#保持自定義控件類不被混淆
-keepclassmembers class * extends android.app.Activity {
   public void *(android.view.View);
}

#保持 Parcelable 不被混淆
-keep class * implements android.os.Parcelable {
  public static final android.os.Parcelable$Creator *;
}

#保持 Serializable 不被混淆
-keepnames class * implements java.io.Serializable

#保持 Serializable 不被混淆而且enum 類也不被混淆
-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();
}

#保持枚舉 enum 類不被混淆 若是混淆報錯,建議直接使用上面的 -keepclassmembers class * implements java.io.Serializable便可
#-keepclassmembers enum * {
#  public static **[] values();
#  public static ** valueOf(java.lang.String);
#}

-keepclassmembers class * {
    public void *ButtonClicked(android.view.View);
}

#不混淆資源類
-keepclassmembers class **.R$* {
    public static <fields>;
}

#避免混淆泛型 若是混淆報錯建議關掉
#–keepattributes Signature

#移除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(...);
#}

另外加上一段,若是用用到Gson解析包的,直接添加下面這幾行就能成功混淆,否則會報錯。 shell

 

#gson
#-libraryjars libs/gson-2.2.2.jar
-keepattributes Signature
# Gson specific classes
-keep class sun.misc.Unsafe { *; }
# Application classes that will be serialized/deserialized over Gson
-keep class com.google.gson.examples.android.model.** { *; }

若是你使用了webview app

# webview + js
-keepattributes *JavascriptInterface*
# keep 使用 webview 的類
-keepclassmembers class  com.veidy.activity.WebViewActivity {
   public *;
}
# keep 使用 webview 的類的全部的內部類
-keepclassmembers  class  com.veidy.activity.WebViewActivity$*{
    *;
}




 

 

你們能夠先看看這篇文章 框架

Android studio 使用心得(四)---android studio 多渠道打包(二)

瞭解一下打包過程。 eclipse

而後你們看看打包的配置文件build.gradle裏面的一段配置代碼 ide

  //混淆,新版本是ninifyEnabled再也不是runproguard
    minifyEnabled true  
 //加載默認混淆配置文件及自定義混淆 配置
   proguardFiles getDefaultProguardFile('proguard-android.txt'),'proguard.cfg'
 
咱們設置minifyEnabled true,就會在打包的時候進行代碼混淆處理. 其中proguard-android.txt不用管,在sdk目錄裏面,咱們主要是配置了proguard.cfg文件。可能你們直接在android studio建立項目不會有這個文件,而是 proguard-rules.pro文件,其實同樣的,我這裏是由於項目是從eclipse遷移過來的,以前在eclipse上混淆是 proguard.cfg文件.

 

一切就緒後,就是打包了。這裏我就再也不多說了,你們能夠去看 工具

 

Android studio 使用心得(四)---android studio 多渠道打包

Android studio 使用心得(四)---android studio 多渠道打包(二) 

 

我這裏用第二種,gradle 命令打包.我建議你們在gradle clean後,不要直接gradle build,而是用gradle assembleRelease .用gradle build第一是由於慢,第二,我本身項目打包時這樣遇到一個錯誤,如今也沒解決

Lint found errors in the project; aborting build.
 
  Fix the issues identified by lint, or add the following to your build script to proceed with errors:
  ...
  android {
      lintOptions {
          abortOnError false
      }
  }
  ...

能夠我明明已經設置

//執行lint檢查,有任何的錯誤或者警告提示,都會終止構建,咱們能夠將其關掉。
    lintOptions {
        abortOnError false
    }
搞不清楚。但願你們誰知道的也告訴下我

 

當咱們執行命令 gradle build或者gradle assembleRelease後,會自動進行混淆操做。。。直到成功。

各位 注意下,若是你的混淆配置有問題,可能會報錯。Execution failed for task ':proguardUmengRelease'.你們能夠根據報錯去排除問題,

好比說我遇到的一個問題,

 


 
 
出現這個問題是由於配置文件裏面我有一行 keepattributes Signature #避免混淆泛型 , 若是混淆報錯建議關掉,由於下面這個就會避免混淆泛型
-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();
}
 
 
你們能夠看到這個錯誤提示,有一個line 168 ,這個是行號,可是各位注意了這個行號定位不是特別精準,只能一個大概的定位。
 
 
 
混淆真正的成功與否,須要咱們本身來親自驗證,那就是咱們來破解本身的apk.我上傳了 一個我使用的破解工具
連接: http://pan.baidu.com/s/1o60tLj0 密碼: 3bqp 
 
1,解壓apk.用好壓就能直接解壓,獲取到classes.dex文件
2.用dex2jar這個工具來生成classes_dex2jar文件.
 a,把剛剛解壓出來的classes.dex文件放到dex2jar根目錄,而後用dos命令定位到該目錄,執行命令dex2jar.bat classes.dex直到done.
 
2.細心的朋友就會發現多了一個jar文件。
.
 c.而後用jd-gui打開這個jar文件,就能看到項目的結構了。。
 
 
若是有a.b.c這些,就說明混淆成功啦
相關文章
相關標籤/搜索