自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Android混淆從入門到精通

移動開發(fā) Android
作為Android開發(fā)者,如果你不想開源你的應用,那么在應用發(fā)布前,就需要對代碼進行混淆處理,從而讓我們代碼即使被反編譯,也難以閱讀。本篇文章的目的就是讓一個初學者在看完后,能在不進行任何幫助的情況下,獨立寫出適合自己代碼的混淆規(guī)則。

簡介

作為Android開發(fā)者,如果你不想開源你的應用,那么在應用發(fā)布前,就需要對代碼進行混淆處理,從而讓我們代碼即使被反編譯,也難以閱讀。混淆概念雖然容易,但很多初學者也只是網上搜一些成型的混淆規(guī)則粘貼進自己項目,并沒有對混淆有個深入的理解。本篇文章的目的就是讓一個初學者在看完后,能在不進行任何幫助的情況下,獨立寫出適合自己代碼的混淆規(guī)則。

說在前面

這里我們直接用Android Studio來說明如何進行混淆,Android Studio自身集成Java語言的ProGuard作為壓縮,優(yōu)化和混淆工具,配合Gradle構建工具使用很簡單,只需要在工程應用目錄的gradle文件中設置minifyEnabled為true即可。然后我們就可以到proguard-rules.pro文件中加入我們的混淆規(guī)則了。

  1. android { 
  2.     ... 
  3.     buildTypes { 
  4.         release { 
  5.             minifyEnabled true 
  6.             proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' 
  7.         } 
  8.     } 
  9.  

以上示例代碼表示對release版本就行混淆處理。下面我們先來簡介下ProGuard的三大作用,并簡要說明下它們常用的命令。

ProGuard作用

壓縮(Shrinking):默認開啟,用以減小應用體積,移除未被使用的類和成員,并且會在優(yōu)化動作執(zhí)行之后再次執(zhí)行(因為優(yōu)化后可能會再次暴露一些未被使用的類和成員)。 

  1. -dontshrink 關閉壓縮 

優(yōu)化(Optimization):默認開啟,在字節(jié)碼級別執(zhí)行優(yōu)化,讓應用運行的更快。

  1. -dontoptimize  關閉優(yōu)化 
  2. -optimizationpasses n 表示proguard對代碼進行迭代優(yōu)化的次數(shù),Android一般為5  

混淆(Obfuscation):默認開啟,增大反編譯難度,類和類成員會被隨機命名,除非用keep保護。

  1. -dontobfuscate 關閉混淆 

混淆后默認會在工程目錄app/build/outputs/mapping/release下生成一個mapping.txt文件,這就是混淆規(guī)則,我們可以根據(jù)這個文件把混淆后的代碼反推回源本的代碼,所以這個文件很重要,注意保護好。原則上,代碼混淆后越亂越無規(guī)律越好,但有些地方我們是要避免混淆的,否則程序運行就會出錯,所以就有了下面我們要教大家的,如何讓自己的部分代碼避免混淆從而防止出錯。

基本規(guī)則

先看如下兩個比較常用的命令,很多童鞋可能會比較迷惑以下兩者的區(qū)別。

  1. -keep class cn.hadcn.test.** 
  2. -keep class cn.hadcn.test.*  

一顆星表示只是保持該包下的類名,而子包下的類名還是會被混淆;兩顆星表示把本包和所含子包下的類名都保持;用以上方法保持類后,你會發(fā)現(xiàn)類名雖然未混淆,但里面的具體方法和變量命名還是變了,這時如果既想保持類名,又想保持里面的內容不被混淆,我們就需要以下方法了

  1. -keep class cn.hadcn.test.* {*;} 

在此基礎上,我們也可以使用Java的基本規(guī)則來保護特定類不被混淆,比如我們可以用extend,implement等這些Java規(guī)則。如下例子就避免所有繼承Activity的類被混淆

  1. -keep public class * extends android.app.Activity 

如果我們要保留一個類中的內部類不被混淆則需要用$符號,如下例子表示保持ScriptFragment內部類JavaScriptInterface中的所有public內容不被混淆。

  1. -keepclassmembers class cc.ninty.chat.ui.fragment.ScriptFragment$JavaScriptInterface { 
  2.    public *; 
  3.  

再者,如果一個類中你不希望保持全部內容不被混淆,而只是希望保護類下的特定內容,就可以使用

  1. <init>;     //匹配所有構造器 
  2. <fields>;   //匹配所有域 
  3. <methods>;  //匹配所有方法方法  

你還可以在<fields>或<methods>前面加上private 、public、native等來進一步指定不被混淆的內容,如

  1. -keep class cn.hadcn.test.One { 
  2.     public <methods>; 
  3.  

表示One類下的所有public方法都不會被混淆,當然你還可以加入參數(shù),比如以下表示用JSONObject作為入參的構造函數(shù)不會被混淆 

  1. -keep class cn.hadcn.test.One { 
  2.    public <init>(org.json.JSONObject); 
  3.  

有時候你是不是還想著,我不需要保持類名,我只需要把該類下的特定方法保持不被混淆就好,那你就不能用keep方法了,keep方法會保持類名,而需要用keepclassmembers ,如此類名就不會被保持,為了便于對這些規(guī)則進行理解,官網給出了以下表格

保留 防止被移除或者被重命名 防止被重命名
類和類成員 -keep -keepnames
僅類成員 -keepclassmembers -keepclassmembernames
如果擁有某成員,保留類和類成員 -keepclasseswithmembers -keepclasseswithmembernames

移除是指在壓縮(Shrinking)時是否會被刪除。以上內容時混淆規(guī)則中需要重點掌握的,了解后,基本所有的混淆規(guī)則文件你應該都能看懂了。再配合以下幾點注意事項,

注意事項

1,jni方法不可混淆,因為這個方法需要和native方法保持一致;

  1. -keepclasseswithmembernames class * { # 保持native方法不被混淆 
  2.     native <methods>; 
  3.  

2,反射用到的類不混淆(否則反射可能出現(xiàn)問題);

3,AndroidMainfest中的類不混淆,所以四大組件和Application的子類和Framework層下所有的類默認不會進行混淆。自定義的View默認也不會被混淆;所以像網上貼的很多排除自定義View,或四大組件被混淆的規(guī)則在Android Studio中是無需加入的;

4,與服務端交互時,使用GSON、fastjson等框架解析服務端數(shù)據(jù)時,所寫的JSON對象類不混淆,否則無法將JSON解析成對應的對象;

5,使用第三方開源庫或者引用其他第三方的SDK包時,如果有特別要求,也需要在混淆文件中加入對應的混淆規(guī)則;

6,有用到WebView的JS調用也需要保證寫的接口方法不混淆,原因和***條一樣;

7,Parcelable的子類和Creator靜態(tài)成員變量不混淆,否則會產生Android.os.BadParcelableException異常; 

  1. -keep class * implements Android.os.Parcelable { # 保持Parcelable不被混淆 
  2.     public static final Android.os.Parcelable$Creator *; 
  3.  

8,使用enum類型時需要注意避免以下兩個方法混淆,因為enum類的特殊性,以下兩個方法會被反射調用,見第二條規(guī)則。 

  1. -keepclassmembers enum * { 
  2.     public static **[] values(); 
  3.     public static ** valueOf(java.lang.String); 
  4.  

寫在***

發(fā)布一款應用除了設minifyEnabled為ture,你也應該設置zipAlignEnabled為true,像Google Play強制要求開發(fā)者上傳的應用必須是經過zipAlign的,zipAlign可以讓安裝包中的資源按4字節(jié)對齊,這樣可以減少應用在運行時的內存消耗。

責任編輯:龐桂玉 來源: Android開發(fā)中文站
相關推薦

2010-02-06 15:31:18

ibmdwAndroid

2009-07-22 14:55:16

ibmdwAndroid

2017-05-09 08:48:44

機器學習

2022-06-10 08:17:52

HashMap鏈表紅黑樹

2012-02-29 00:49:06

Linux學習

2025-02-24 10:07:10

2010-11-08 10:20:18

2024-02-26 08:52:20

Python傳遞函數(shù)參數(shù)參數(shù)傳遞類型

2022-09-02 15:11:18

開發(fā)工具

2011-06-07 10:33:11

Android Activity

2023-10-13 08:23:05

2009-07-03 18:49:00

網吧綜合布線

2011-10-26 20:47:36

ssh 安全

2024-06-07 08:51:50

OpenPyXLPythonExcel文件

2009-03-19 13:36:53

SSH安全通道遠程

2025-03-21 14:31:14

NumPyPython數(shù)組

2017-01-09 09:34:03

Docker容器傳統(tǒng)虛擬機

2010-02-07 10:25:11

Android

2023-05-09 08:34:51

PythonWith語句

2024-01-11 09:35:12

單元測試Python編程軟件開發(fā)
點贊
收藏

51CTO技術棧公眾號