凡事都有兩面性,各有利弊。科學技術的發展給人們帶來便利的同時,也帶來了意想不到的隱患。有越來越多的手機和手機應用,但你覺得越來越安全嗎?由于安卓系統的開源性,手機應用很容易被黑客攻擊,被注入惡意代碼,并在打包兩次后重新上市。在這里,損失不僅是手機用戶,也是手機應用開發者和開發者。現在,尋求手機應用的加密方案,保護手機應用的安全迫在眉睫!
偽加密1偽加密是安卓4.2.x系統發布前的手機應用加密方案之一。APK(壓縮文件)被java代碼偽加密。它的修改原理是將最后一個第5字節修改為連續的4位字節,標記為“PK0102”。奇數表示不加密,偶數表示加密。
2
雖然偽加密在防止破解方面可以發揮一定的作用,但也會有問題。首先,市場無法對通過偽加密加密的APK進行安全檢測,導致一些市場拒絕此類APK上傳。其次,偽加密的加密方法和解密方法已經公布,導致安全性大大降低。第三,安卓4.2.x系統不能安裝偽加密APK;;最后,偽加密對APK來說只是一個簡單的保護,但在java層源代碼外殼保護、核心so庫、資源文件、主分發文件和第三方架子包中沒有保護。手機應用加密方案
結束混淆保護1將具有特定含義的原始類名、變量名和方法名修改為人們無法理解的名稱。例如,方法名getUserName對方法名進行了編程。手機應用加密方案
混淆保護只會增加代碼閱讀的難度,破解它基本上是沒有用的!手機應用加密方案
結束運行時驗證1運行時驗證主要是指在代碼啟動時在本地獲取簽名信息,然后檢查簽名信息以確定您的應用程序是否是真實的。如果簽名信息不是真實的,它將提示盜版或直接崩潰。當然,您可以將必要的數據放在服務器端。手機應用加密方案
破解:找到smali文件中的部分,判斷它是否相等。更改為常量true,即無效。
簡而言之,在反編譯一些apk之后,只要是用java代碼寫的,總是會有smil文件。對于smil文件,如果你耐心閱讀,你仍然可以看到一些關鍵代碼。
3與應用程序相比,游戲apk使用由c++和c#編寫的跨平臺程序,因為它使用cocos2d-x或unity3D,并在apk中使用JNI。因此,如果沒有smali,靜態apk數據包就不會被破解。手機應用加密方案
當然,當apk運行時,它會加載。*如此進入記憶。動態也可以在內存中捕獲相應的數據。然而,NDK不是一個等級關系與斯馬利裂解。手機應用加密方案
終端使用第三方手機應用加密平臺1進行實例分析
步驟閱讀2這個類. dex是原始代碼。沒有混淆和手機應用加密方案保護。反編譯,源代碼無疑是暴露的。
這個類. dex是由AndroidAPK加密的。現在看看反編譯后的效果。手機應用加密方案
-3步讀取4NativeApplication類,load exec.so和execmain.so,應該是固定代碼,是源代碼
-4步讀取5從應用程序繼承的超級應用程序,程序主條目:
-5步閱讀6在手機APP加密方案后的apk包中,有一個附加的資產目錄。在這個目錄下,有一些數據庫。事實上,這是原始的分類索引
-6步讀取結束摘要Agami手機應用加密方案步驟:
1.使用安卓加密算法將原始分類索引加密成資產
2.將預先編寫的jni代碼和相應的classex.dex替換到原來的位置
3.程序安裝運行后,首先運行手機APP加密方案的加密外殼程序,并在jni中動態加載原classex.dex代碼,從而達到保護手機APP加密方案的目的。
源代碼classex.dex是隱藏的,當它是靜態的時候沒有辦法破解它。
目標