Android 逆向分析

今日公司有需求印屁,需要破解某知名網(wǎng)站android apk登錄原理。進(jìn)過多天的艱難前行稼锅,終于搞定了『鹁撸現(xiàn)將技術(shù)方法記錄如下。

原料:

1.需要破解的apk(盡量找之前的低版本破解缰贝,混淆程度低馍悟,未加殼)

  1. dex2jar-2.0

  2. jd-gui

  3. android studio

  4. android 逆向助手

  5. apktool

開始破解

  1. 將apk后綴改成zip,然后解壓
  2. 將其中的所有dex 用 dex2jar-2.0工具轉(zhuǎn)換成為jar包剩晴,方便查看锣咒。轉(zhuǎn)換命令為:
 d2j-dex2jar.bat classes.dex
  1. 將轉(zhuǎn)換后的jar包拖到 jd-gui中,定位需要修改的地方赞弥。找到該文件的包名及源碼
  2. 在android studio中新建工程毅整,按照上述文件簡(jiǎn)歷完整包名,并在包下創(chuàng)建同名類绽左,然后將代碼全部拷貝到該類中悼嫉。
  3. 添加log代碼
  4. gradle build
  5. 在intermediates/class/.... 中找到編譯好的.class文件

此時(shí),就生成了class文件拼窥。需要將該class文件覆蓋到源代碼中戏蔑。具體方法如下:

  1. 將之前生成的jar包,用zip工具打開鲁纠,比如我用的3456好壓打開总棵,打開文件所在目錄,可以直接粘貼覆蓋改含。
  2. 然后將jar包用dex2jar-2.0工具重新編譯生成dex文件情龄,命令如下:
d2j-jar2dex.bat classes-dex2jar.jar
  1. 這時(shí)需要將apk重新簽名打包。如果直接簽名打包的話捍壤,會(huì)安裝失敗骤视,因?yàn)镸ETE-INF文件夾中是用來對(duì)apk文件進(jìn)行加密校驗(yàn)用的。我采用的方法是直接刪除該文件夾鹃觉,然后對(duì)剩余的文件全部打包成壓縮文件zip专酗。再將zip改成apk,最后用android逆向助手進(jìn)行簽名盗扇。就完成了對(duì)原有代碼的邏輯注入笼裳。
5ba1b5a9c52db_5ba1b5a9.png

遇到的缺點(diǎn):
第六步中唯卖,gradle build的過程中,會(huì)遇到?jīng)]有包依賴的情況躬柬。這個(gè)情況感覺是無解的拜轨,即使用javac編譯也無法正確編譯為.class文件。

方法二:

采用更改smail文件的方法允青。大家都知道橄碾,smail文件是生成.class文件的前一步,通過反編譯我們可以得到所有文件的smail文件颠锉。方法是:

 apktool.bat d xxx.apk

這時(shí)就可以拿到整個(gè)apk的smail文件法牲。我們需要對(duì)smail語法做一個(gè)簡(jiǎn)單初步的了解。

.local n 表示需要的最少寄存器個(gè)數(shù)琼掠。

Dalvik VM與JVM的最大的區(qū)別之一就是Dalvik VM是基于寄存器的拒垃。
基于寄存器是什么意思呢?也就是說瓷蛙,在smali里的所有操作都必須經(jīng)過寄存器來進(jìn)行:
本地寄存器用v開頭數(shù)字結(jié)尾的符號(hào)來表示悼瓮,如v0、v1艰猬、v2横堡、...(本地寄存器沒有限制,理論上是可以任意使用的)
參數(shù)寄存器則使用p開頭數(shù)字結(jié)尾的符號(hào)來表示冠桃,如p0命贴、p1、p2食听、...
特別注意的是胸蛛,p0不一定是函數(shù)中的第一個(gè)參數(shù),在非static函數(shù)中樱报,p0代指“this”胚泌,p1表示函數(shù)的第一個(gè)參數(shù),p2代表函數(shù)中的第二個(gè)參數(shù)…
而在static函數(shù)中p0才對(duì)應(yīng)第一個(gè)參數(shù)(因?yàn)镴ava的static方法中沒有this方法)肃弟。

這次我只需要打一個(gè)log查看一下原apk的某個(gè)參數(shù),因此只需要打一個(gè)log即可零蓉。其他smail語法請(qǐng)自行百度笤受。
log方法在android中需要兩個(gè)參數(shù):

Log.e("ivan paramString = ", paramString);

但第二個(gè)參數(shù)是原程序的,也就是只有第一個(gè)參數(shù)是新增參數(shù)敌蜂,因此需要增加一個(gè)寄存器箩兽。修改方法最上面的local變量

.local n+1 表示需要的最少寄存器個(gè)數(shù)。

然后添加log方法的smail語法:

const-string v1, "ivan paramString ="
invoke-static {v1,p0}, Landroid/util/Log;->v(Ljava/lang/String;Ljava/lang/String;)I

這樣就修改好了smail代碼章喉。接下來進(jìn)行打包編譯

apktool b xxx -o temp.apk

這樣打包出來的temp.apk是沒有簽名的汗贫,安裝是失敗的身坐。因此還需要借助android 逆向助手進(jìn)行簽名后,即可安裝運(yùn)行落包,查看到log部蛇。

5ba1b5a9c52db_5ba1b5a9.png

有問題可+qq 807736118討論。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末咐蝇,一起剝皮案震驚了整個(gè)濱河市涯鲁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌有序,老刑警劉巖抹腿,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異旭寿,居然都是意外死亡警绩,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門盅称,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肩祥,“玉大人,你說我怎么就攤上這事微渠〈罨茫” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵逞盆,是天一觀的道長(zhǎng)檀蹋。 經(jīng)常有香客問我,道長(zhǎng)云芦,這世上最難降的妖魔是什么俯逾? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮舅逸,結(jié)果婚禮上桌肴,老公的妹妹穿的比我還像新娘。我一直安慰自己琉历,他們只是感情好坠七,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著旗笔,像睡著了一般彪置。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蝇恶,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天拳魁,我揣著相機(jī)與錄音,去河邊找鬼撮弧。 笑死潘懊,一個(gè)胖子當(dāng)著我的面吹牛姚糊,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播授舟,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼救恨,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了岂却?” 一聲冷哼從身側(cè)響起忿薇,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎躏哩,沒想到半個(gè)月后署浩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡扫尺,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年筋栋,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片正驻。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡弊攘,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤新啼,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站捣域,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏宴合。R本人自食惡果不足惜焕梅,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望卦洽。 院中可真熱鬧贞言,春花似錦、人聲如沸阀蒂。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蚤霞。三九已至酗失,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間争便,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國(guó)打工断医, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留滞乙,地道東北人奏纪。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像斩启,于是被迫代替她去往敵國(guó)和親序调。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容