iOS逆向工程之艱辛的學(xué)習(xí)之路___代碼寫入

前言

從朋友那里聽到關(guān)于逆向編程這個(gè)東東的時(shí)候,我是懵逼的,現(xiàn)在終于有時(shí)間來填補(bǔ)我懵逼的大腦了.網(wǎng)上好多關(guān)于逆向工程的文檔,都寫得很牛逼,奈何自己書讀少,寫不出來那么6的文章,所以賤文只為了記錄自己的踩坑過程.

工具

MachOView

使用MachOView工具可以在Mac平臺(tái)中可查看Mach-O文件的格式信息.iOS系統(tǒng)中可執(zhí)行程序就屬于Mach-O文件格式谜嫉。

MachOView官網(wǎng)下載的使用很容易閃退,不過有大佬已經(jīng)幫我們解決了,參考簡(jiǎn)書

避免簡(jiǎn)書無法瀏覽,參考操作步驟如下:

????1. MachOView工具屬于免費(fèi)開源項(xiàng)目,源代碼可在https://github.com/gdbinit/MachOView下載

????2. 將上個(gè)網(wǎng)址下載的源碼編譯出.app,將.app拖到電腦的應(yīng)用工程中可使用

????????2.1 編譯會(huì)出現(xiàn)以下問題

問題1

????????????2.1.2 問題二

問題2

解決如下:

問題2解決方法

yololib

yololib可以給mach-o文件注入framework

?重簽名APP

首先準(zhǔn)備一個(gè)越獄的ipa.可以從PP助手下載.也可以自己砸殼獲取,任君選擇

1.使用第三方實(shí)現(xiàn)

第三方操作步驟參考官網(wǎng)文檔也可以參考博客

2.使用xcode加腳本實(shí)現(xiàn)

新建項(xiàng)目,在根目錄里新建一個(gè)APP文件夾(此處用來放置你的ipa包),現(xiàn)將空項(xiàng)目(ipa包還沒放置到APP文件夾中)運(yùn)行到自己手機(jī)上,是為了將描述文件安裝到手機(jī)上.


然后在Build Phases中創(chuàng)建一個(gè)編譯腳本.


可將腳本保存為AssignApp.sh文件,放到項(xiàng)目根目錄中


在新建的Run Script中寫入AssignApp.sh文件路徑(也可以將腳本直接粘貼在此處)

注:如果運(yùn)行項(xiàng)目報(bào)關(guān)于腳本文件錯(cuò),如下:


解決方法如下??sudo chmod -R 777 項(xiàng)目路徑

運(yùn)行的時(shí)候Xcode就會(huì)自動(dòng)幫我們重簽名,

注意:?如果你的ipa中沒有Framework,那就注釋掉?# 6. 重簽名第三方 下面的腳本

腳本內(nèi)容如下:

# ${SRCROOT} 它是工程文件所在的目錄

TEMP_PATH="${SRCROOT}/Temp"

#資源文件夾

ASSETS_PATH="${SRCROOT}/APP"

#ipa包路徑

TARGET_IPA_PATH="${ASSETS_PATH}/*.ipa"

#新建Temp文件夾

rm -rf "${SRCROOT}/Temp"

mkdir -p "${SRCROOT}/Temp"

#----------------------------------------

# 1. 解壓IPA到Temp下

unzip -oqq "$TARGET_IPA_PATH" -d "$TEMP_PATH"

# 拿到解壓的臨時(shí)的APP的路徑

TEMP_APP_PATH=$(set -- "$TEMP_PATH/Payload/"*.app;echo "$1")

# echo "路徑是:$TEMP_APP_PATH"

#----------------------------------------

#2. 將解壓出來的.app拷貝進(jìn)入工程下

# BUILT_PRODUCTS_DIR 工程生成的APP包的路徑

# TARGET_NAME target名稱

TARGET_APP_PATH="$BUILT_PRODUCTS_DIR/$TARGET_NAME.app"

echo "app路徑:$TARGET_APP_PATH"

rm -rf "$TARGET_APP_PATH"

mkdir -p "$TARGET_APP_PATH"

cp -rf "$TEMP_APP_PATH/" "$TARGET_APP_PATH"

#----------------------------------------

# 3. 刪除extension和WatchAPP.個(gè)人證書沒法簽名Extention

rm -rf "$TARGET_APP_PATH/PlugIns"

rm -rf "$TARGET_APP_PATH/Watch"

#----------------------------------------

#4. 更新info.plist文件 CFBundleIdentifier

#? 設(shè)置:"Set : KEY Value" "目標(biāo)文件路徑"

/usr/libexec/PlistBuddy -c "Set :CFBundleIdentifier $PRODUCT_BUNDLE_IDENTIFIER" "$TARGET_APP_PATH/Info.plist"

#----------------------------------------

# 5. 給MachO文件上執(zhí)行權(quán)限

# 拿到MachO文件的路徑

APP_BINARY=`plutil -convert xml1 -o - $TARGET_APP_PATH/Info.plist|grep -A1 Exec|tail -n1|cut -f2 -d\>|cut -f1 -d\<`

#上可執(zhí)行權(quán)限

chmod +x "$TARGET_APP_PATH/$APP_BINARY"

#----------------------------------------

# 6. 重簽名第三方 FrameWorks

#如果你的ipa中沒有Framework,那就注釋這段代碼

TARGET_APP_FRAMEWORKS_PATH="$TARGET_APP_PATH/Frameworks"

if [ -d "$TARGET_APP_FRAMEWORKS_PATH" ];? ?

then

for FRAMEWORK in "$TARGET_APP_FRAMEWORKS_PATH/"*

do

#簽名

/usr/bin/codesign --force --sign "$EXPANDED_CODE_SIGN_IDENTITY" "$FRAMEWORK"

done

fi

代碼注入

1.通過工具M(jìn)achOView查看.app包內(nèi)容的應(yīng)用可執(zhí)行文件,可見到應(yīng)用中的Framwork文件.

MachOView

我們可通過向應(yīng)用可執(zhí)行文件中注入自己的Framwork實(shí)現(xiàn)自己代碼的操作.而如何注入自己的Framwork? 通過工具yololib可實(shí)現(xiàn).

1.1 下載yololib源碼運(yùn)行,得到y(tǒng)ololib工具.

yololib工具

我們將yololib工具與應(yīng)用可執(zhí)行文件放在同一文件夾中,方便操作.

2. 手動(dòng)注入:?

通過命令cd 進(jìn)入文件夾,然后通過命令?./yololib PUClient Frameworks/PFFramework.framework/PFFramework? 注入自己的PFFramework.成功之后通過MachOView查看應(yīng)用可執(zhí)行文件可發(fā)現(xiàn)我們注入的PFFramework

注入PFFramework完成

3. 進(jìn)入我們項(xiàng)目根目錄->Temp->Payload->應(yīng)用程序顯示包內(nèi)容,將包中的可執(zhí)行文件替換為我們注入之后的可執(zhí)行文件,然后刪除Temp中文件只保留Payload文件夾.

2.1 自動(dòng)注入:?

?腳本注入

?在上面的腳本內(nèi)容后面加入下面內(nèi)容: (PFFramework 修改為自己命名的Framework)

#寫入

yololib "$TARGET_APP_PATH/$APP_BINARY"

? ? ? ? ? ? "Frameworks/PFFramework.framework/PFFramework"

3.1 通過命令進(jìn)入項(xiàng)目的Temp文件, 敲入命令?zip -ry PUClient.ipa Payload ,將Payload打包,可得到一個(gè).ipa文件.

3.2 將APP文件中的ipa替換為我們打包的.ipa文件.此時(shí)不可運(yùn)行項(xiàng)目,由于我們引入了自己的Framwork,但是項(xiàng)目并沒有找到這個(gè)Framwork,因此運(yùn)行失敗.從失敗原因我們可知下步操作,需引入運(yùn)行需要的Framwork.

4. 新建我們的Framwork,點(diǎn)擊+新建, 選擇 Framwork,命名要操作2中的名字相同 (PFFramework)

新建

4.1 在項(xiàng)目的PFFramework文件夾新建一個(gè)Inject類,寫入方法.

4.2 編譯運(yùn)行項(xiàng)目,查看控制臺(tái)可看到我們寫入的代碼

想要其他操作可簡(jiǎn)單先通過runtime.

學(xué)無止境,將我的學(xué)習(xí)過程分享出去,希望可以幫助到你.

純粹學(xué)習(xí)哦!!!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末录粱,一起剝皮案震驚了整個(gè)濱河市坎穿,隨后出現(xiàn)的幾起案子溉箕,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件屿储,死亡現(xiàn)場(chǎng)離奇詭異昭灵,居然都是意外死亡吠裆,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門烂完,熙熙樓的掌柜王于貴愁眉苦臉地迎上來试疙,“玉大人,你說我怎么就攤上這事抠蚣∽?酰” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵嘶窄,是天一觀的道長(zhǎng)怀跛。 經(jīng)常有香客問我,道長(zhǎng)柄冲,這世上最難降的妖魔是什么吻谋? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮现横,結(jié)果婚禮上漓拾,老公的妹妹穿的比我還像新娘。我一直安慰自己戒祠,他們只是感情好晦攒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著得哆,像睡著了一般脯颜。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上贩据,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天栋操,我揣著相機(jī)與錄音闸餐,去河邊找鬼。 笑死矾芙,一個(gè)胖子當(dāng)著我的面吹牛舍沙,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播剔宪,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼拂铡,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了葱绒?” 一聲冷哼從身側(cè)響起感帅,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎地淀,沒想到半個(gè)月后失球,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡帮毁,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年实苞,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片烈疚。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡黔牵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出爷肝,到底是詐尸還是另有隱情荧止,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布阶剑,位于F島的核電站,受9級(jí)特大地震影響危号,放射性物質(zhì)發(fā)生泄漏牧愁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一外莲、第九天 我趴在偏房一處隱蔽的房頂上張望猪半。 院中可真熱鬧,春花似錦偷线、人聲如沸磨确。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)乏奥。三九已至,卻和暖如春亥曹,著一層夾襖步出監(jiān)牢的瞬間邓了,已是汗流浹背恨诱。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留骗炉,地道東北人照宝。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像句葵,于是被迫代替她去往敵國(guó)和親厕鹃。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355