android 代碼 混淆- 原來如此簡單

來源:互聯網
上載者:User

一個xxx.apk提交給測試、

ok,去倒杯水,看看網頁~~~~~

呃,忽然覺得 是不是應該 給My Code 提高點安全性,

記得看過 apk直接可以 解壓,然後很容易的就可以 反編譯出 .java

找了找,果然,這一切 只不過是 一分鐘的事兒,

1、得到 classes.dex檔案;直接用你機器上的  解壓軟體 開啟 .apk 檔案

  解壓出 classes.dex 檔案,(這個就是 .jar 的前生--- 其實應該說 後世)

  

2、還原.jar檔案;這一步需要用到一個工具 dex2jar (Google的程式碼程式庫裡有 http://code.google.com/p/dex2jar/)

  看名字也不難知道他是幹嘛的了吧?(沒錯,就是 把 dex 還原 成  jar包 )

  下載完了,解壓,然後把第一步的 產物(即那個classes.dex檔案)放到 dex2jar的解壓目錄裡

  (解壓目錄裡 有 dex2jar.bat 檔案,檢查一下,沒有的話 說明目錄不對、再 找找)

  

  cmd 命令列 ,目錄切換到 dex2jar的目錄下(linux 系統的話 執行那個 .sh檔案)

  “ dex2jar.bat classes.dex”

  看到命令列  的 “Done” 之後, dex2jar 檔案夾裡 就會有“classes.dex.dex2jar.jar” 檔案了,

  這個就是 傳說中的 jar包了

  

3、查看.jar檔案;這一步就是傳統的 反編譯 了,需要工具輔助,我這裡用到的工具是jd-gui(http://java.decompiler.free.fr/?q=jdgui)

  下載你的系統對應的版本,解壓,(我xp系統)你會看到一個 .exe檔案,沒錯就是 單檔案綠色版

  雙擊,選擇 第二步 產生的 .jar, 好吧,你的項目是不是 完全還原了呢?(內部類的話 還原後的結構看著有點不喜歡)

沒錯,這麼簡單 就能 讓你的代碼暴露了,心疼不?

[這裡我就不貼 圖了,公司的項目]

好了,接下來說說  怎麼混淆吧,網路上好多介紹 proguard 混淆android 項目的文章,都是抄來貼去,

好幾個都是講得沒頭沒尾、我看了好半天  ,愣是沒搞明白,……

android sdk \ tools 目錄下 看到 proguard 了沒?

建立一個 2.3.3的項目,你會看到 項目 檔案裡 有一個 proguard.cfg 檔案?

好吧,偉大的 google 已經幫我們做了這麼多事兒了,可惜是從2.3開始的,

那我 悲催的 項目(基於2.2的sdk) 該如何 是好?(非得 殘忍的把 項目屬性設定為 2.3的嗎?

其實即使你該了,google 也不會為你把 proguard.cfg檔案補上的)

呵呵,其實不用,你只要 把 proguard.cfg 檔案 拷貝到 你的 舊項目裡就好了,

當然這樣還不夠,因為 google是預設不混淆項目的

To enable ProGuard so that it runs as part of an Ant or Eclipse build, 

set the proguard.config property in the <project_root>/default.properties file. 

The path can be an absolute path or a path relative to the project's root.  

google 告訴我們 還要 配置 default.properties 

嗯,

把 proguard.config=proguard.cfg 加上

好了,再次產生 新的  .apk檔案,

然後用上面的方法 反編譯你的 項目,你會看到 aa bb cc 的包、aa bb cc 的類 和 aa bb cc 的變數名,方法名.

這個我相信你自己也搞的頭昏了吧?

再看看 proguard.cfg 檔案

-optimizationpasses 5-dontusemixedcaseclassnames-dontskipnonpubliclibraryclasses-dontpreverify-verbose-optimizations !code/simplification/arithmetic,!field/*,!class/merging/*-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 com.android.vending.licensing.ILicensingService-keepclasseswithmembernames class * {    native <methods>;}-keepclasseswithmembernames class * {    public <init>(android.content.Context, android.util.AttributeSet);}-keepclasseswithmembernames class * {    public <init>(android.content.Context, android.util.AttributeSet, int);}-keepclassmembers enum * {    public static **[] values();    public static ** valueOf(java.lang.String);}-keep class * implements android.os.Parcelable {  public static final android.os.Parcelable$Creator *;}

如果沒有此檔案,就自己建立一個。

這裡是 google預設 不混淆 Activity 、Service ... 類的 子類, 正如上面的中看到的 所有 activity 的子類 名稱是被保留的。

想自訂 混淆細節 的話 就 琢磨琢磨這個設定檔吧

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.