錦州市廣廈電腦維修|上門(mén)維修電腦|上門(mén)做系統(tǒng)|0416-3905144熱誠(chéng)服務(wù),錦州廣廈維修電腦,公司IT外包服務(wù)
topFlag1 設(shè)為首頁(yè)
topFlag3 收藏本站
 
maojin003 首 頁(yè) 公司介紹 服務(wù)項(xiàng)目 服務(wù)報(bào)價(jià) 維修流程 IT外包服務(wù) 服務(wù)器維護(hù) 技術(shù)文章 常見(jiàn)故障
錦州市廣廈電腦維修|上門(mén)維修電腦|上門(mén)做系統(tǒng)|0416-3905144熱誠(chéng)服務(wù)技術(shù)文章
阿里系產(chǎn)品Xposed Hook檢測(cè)機(jī)制原理分析

作者: 技術(shù)那些事  日期:2017-07-07 10:15:56   來(lái)源: 本站整理

 導(dǎo)語(yǔ): 在逆向分析android App過(guò)程中,我們時(shí)常用的用的Java層hook框架就是Xposed Hook框架了。一些應(yīng)用程序廠商為了保護(hù)自家android App不被Xposed Hook框架給hook。于是想盡各種方法檢測(cè)自己產(chǎn)品是否被Xposed Hook給Hook。筆者最近逆向分析阿里系的產(chǎn)品,發(fā)現(xiàn)阿里系的產(chǎn)品能夠檢測(cè)自否給Xposed Hook了。本文就帶領(lǐng)給位一起看看官阿里系產(chǎn)品是如何做的這一點(diǎn)的,本文就選擇阿里的支付寶作為我們分析對(duì)象。檢測(cè)現(xiàn)象:1. 編寫(xiě)一個(gè)簡(jiǎn)單的支付寶的Xposed hook 模塊, 模塊代碼如下: 
2.安裝XPosed hook mo模塊,重啟設(shè)備,打開(kāi)支付寶,就會(huì)看到如下一個(gè)對(duì)話(huà)框:非法操作的,你的手機(jī)不安全。這說(shuō)明支付寶檢測(cè)自己被Hook了。
 
分析過(guò)程:0.分析工具和分析對(duì)象樣本:Alipay_wap_main_10.0.18 工具:AndroidkillerJEB2.2.7源碼:XPosed 框架源碼 1. 為了快速找到代碼Xposed的檢測(cè)代碼位置,我們就不從對(duì)話(huà)框作為分析入口啦,我們直接使用androidKiller打開(kāi)文件Alipay_wap_main_10.0.18.apk, 然后在工程中搜索xposed相關(guān)的關(guān)鍵字,例如:xposed
 
根據(jù)搜索結(jié)果,我們找到看了兩個(gè)security相關(guān)的類(lèi)。我們使用JEB工具對(duì)這兩個(gè)類(lèi)進(jìn)行分析,我們暫且分析CheckInject類(lèi)。
 
我們看到這里獲得通過(guò)反射獲得一個(gè)類(lèi)de.robv.android.xposed.XposedHelpers 的一個(gè)對(duì)象,于是我們可以確認(rèn)發(fā)現(xiàn)代碼就這里。 3. 由于Smali代碼是經(jīng)過(guò)混淆的代碼,不便于讀者閱讀,于是筆者將代碼整理如下:  
通過(guò)反射獲取de.robv.android.xposed.XposedHelpers類(lèi)的一個(gè)對(duì)象obXposedHelper,然后調(diào)用CheckKeywordInFiled 檢測(cè)obXposedHelper成員fieldCache,methodCache,constructorCache是否有支付寶包的關(guān)鍵字,CheckInject.CheckKeywordInFiled, 這個(gè)函數(shù)代碼 。筆者也這個(gè)函數(shù)整理如下:
 
fieldCache, methodCache,constructorCache然是XposedHelpers的靜態(tài)成員,類(lèi)型是HashMap<String, Field> 
    
通過(guò)反射遍歷這些HashMap 緩存字段, 如字段項(xiàng)的key中包含支付寶的關(guān)鍵字"alipy" "taobao",等信息, 者認(rèn)為是檢測(cè)有Xposed 注入 4.我們來(lái)繼續(xù)分析Xposed hook框架是如何將hook信息存儲(chǔ)到fieldCache,methodCache,constructorCache這些緩存字段當(dāng)中的(我們需要下載XPosed 源碼分析,github有下載)。我們最通常調(diào)用findAndHookMethod 函數(shù)hook一個(gè)函數(shù), 所以我們分析這個(gè)函數(shù),函數(shù)代碼如下:
 
這個(gè)函數(shù)我們暫時(shí)還無(wú)法看到存儲(chǔ)相關(guān)的代碼,這個(gè)主要實(shí)現(xiàn)依賴(lài)函數(shù)findMethodExact, 于是我們繼續(xù)分析
 
我們發(fā)現(xiàn) methodCache.put(fullMethodName, e); 將方法名和方法Method 存儲(chǔ)在方法緩存中嗎。 5.CheckInject類(lèi)類(lèi)中除了有XPosed 檢測(cè), 還有SO注入檢測(cè)機(jī)制的代碼和手機(jī)檢測(cè)是否Root的代碼。筆者也將這些代碼整理分享給各位看官:● Root檢測(cè)代碼如下 
檢測(cè)依據(jù)是:獲取default.prop 中文件ro.secure的值1 且 /system/bin/ 或者/system/xbin 有su程序可認(rèn)定程序被root了 ● So注入檢測(cè)由于實(shí)現(xiàn)比較簡(jiǎn)單,就不貼代碼,直接闡述原理吧。SO注入檢測(cè)原理:讀取當(dāng)前進(jìn)程的maps文件, 遍歷每一行, 是否進(jìn)程中使用so名中包含關(guān)鍵"hack|inject|hook|call" 的信息,“hack|inject|hook|call” 字符信息使用Base64加密, 如下:
 
分析結(jié)論和安全建議:結(jié)論:1.支付寶的Xposed hook 檢測(cè)原理: Xposed Hook 框架將Hook信息存儲(chǔ)在fieldCache, methodCache,constructorCache 中, 利用java 反射機(jī)制獲取這些信息,檢測(cè)Hook信息中是否含有支付寶App中敏感的方法,字段,構(gòu)造方法。2.支付寶的SO檢測(cè)原理: 檢測(cè)進(jìn)程中使用so名中包含關(guān)鍵"hack|inject|hook|call" 的信息。3.支付寶的Root檢測(cè): 是否含有su程序和ro.secure是否為1安全建議:像這些 "de.robv.android.xposed.XposedHelpers","fieldCache","methodCache","constructorCache" 想這些敏感字符串信息可以進(jìn)行一些簡(jiǎn)單加密。防止用戶(hù)直接根據(jù)關(guān)鍵字搜索找到關(guān)鍵函數(shù)。同時(shí)對(duì)dex相關(guān)內(nèi)容進(jìn)行加密,DEX加密之后反編譯的難度大大增加,這里支持下朋友公司幾維安全的APK加密產(chǎn)品,歡迎大家體驗(yàn)他們的移動(dòng)加密產(chǎn)品 



熱門(mén)文章
  • 機(jī)械革命S1 PRO-02 開(kāi)機(jī)不顯示 黑...
  • 聯(lián)想ThinkPad NM-C641上電掉電點(diǎn)不...
  • 三星一體激光打印機(jī)SCX-4521F維修...
  • 通過(guò)串口命令查看EMMC擦寫(xiě)次數(shù)和判...
  • IIS 8 開(kāi)啟 GZIP壓縮來(lái)減少網(wǎng)絡(luò)請(qǐng)求...
  • 索尼kd-49x7500e背光一半暗且閃爍 ...
  • 樓宇對(duì)講門(mén)禁讀卡異常維修,讀卡芯...
  • 新款海信電視機(jī)始終停留在開(kāi)機(jī)界面...
  • 常見(jiàn)打印機(jī)清零步驟
  • 安裝驅(qū)動(dòng)時(shí)提示不包含數(shù)字簽名的解...
  • 共享打印機(jī)需要密碼的解決方法
  • 圖解Windows 7系統(tǒng)快速共享打印機(jī)的...
  • 錦州廣廈電腦上門(mén)維修

    報(bào)修電話(huà):13840665804  QQ:174984393 (聯(lián)系人:毛先生)   
    E-Mail:174984393@qq.com
    維修中心地址:錦州廣廈電腦城
    ICP備案/許可證號(hào):遼ICP備2023002984號(hào)-1
    上門(mén)服務(wù)區(qū)域: 遼寧錦州市區(qū)
    主要業(yè)務(wù): 修電腦,電腦修理,電腦維護(hù),上門(mén)維修電腦,黑屏藍(lán)屏死機(jī)故障排除,無(wú)線(xiàn)上網(wǎng)設(shè)置,IT服務(wù)外包,局域網(wǎng)組建,ADSL共享上網(wǎng),路由器設(shè)置,數(shù)據(jù)恢復(fù),密碼破解,光盤(pán)刻錄制作等服務(wù)

    技術(shù)支持:微軟等
    主站蜘蛛池模板: 国产AV无码专区亚洲AV男同| h无码动漫在线观看| 未满小14洗澡无码视频网站| 亚洲AV无码乱码国产麻豆| 18禁免费无码无遮挡不卡网站| 无码一区二区三区亚洲人妻| 无码视频在线观看| 久久美利坚合众国AV无码| 久久久久亚洲精品无码系列 | 日韩精品无码永久免费网站| 亚洲AV永久无码区成人网站| 无码中文av有码中文a| 久久久久久亚洲av成人无码国产 | 久久综合精品国产二区无码| 无码色偷偷亚洲国内自拍| 亚洲AV无码一区二区三区在线| 国精品无码一区二区三区在线蜜臀| 少妇无码AV无码专区线| 日韩av无码久久精品免费| 国内精品人妻无码久久久影院| 亚洲AV无码乱码在线观看牲色| 亚洲GV天堂GV无码男同| 无码精品尤物一区二区三区| 亚洲AV无码专区电影在线观看| 国产精品无码素人福利不卡| 免费无码不卡视频在线观看| 无码中文av有码中文av| 激情无码亚洲一区二区三区 | 潮喷失禁大喷水aⅴ无码| 无码国产69精品久久久久孕妇| 无码人妻精品内射一二三AV| 亚洲综合无码无在线观看| 亚洲精品无码专区| 亚洲精品GV天堂无码男同| 亚洲av永久中文无码精品综合| 无码中文人妻在线一区二区三区| 亚洲av无码片vr一区二区三区| 亚洲av永久无码精品秋霞电影秋| 国产怡春院无码一区二区| 国产精品亚洲а∨无码播放不卡| 亚洲成A∨人片天堂网无码|