Theos-tweak工程

1螟深、查看《iOS逆向 開發(fā)工具》 Theos的使用方法做準備工作赠尾;
2毡证、創(chuàng)建tweak工程转砖,實現(xiàn)在屏幕上添加彈框(越獄手機);
3诞外、Logos語法澜沟。
完成該工程,我們可以實現(xiàn)在任意地方添加我們想要的功能峡谊。任性茫虽,吼吼刊苍。

一、給屏幕添加彈框

項目目錄:/Users/yanghaibo/Documents/iOS逆向/Theos/

1濒析、創(chuàng)建tweak工程正什,進入工程目錄執(zhí)行命令:

/opt/theos/bin/nic.pl  

會出現(xiàn)列表:

NIC 2.0 - New Instance Creator
------------------------------
  [1.] iphone/activator_event
  [2.] iphone/application_modern
  [3.] iphone/application_swift
  [4.] iphone/cydget
  [5.] iphone/flipswitch_switch
  [6.] iphone/framework
  [7.] iphone/ios7_notification_center_widget
  [8.] iphone/library
  [9.] iphone/notification_center_widget
  [10.] iphone/preference_bundle_modern
  [11.] iphone/tool
  [12.] iphone/tool_swift
  [13.] iphone/tweak
  [14.] iphone/xpc_service
Choose a Template (required):

2、選擇13創(chuàng)建一個tweak工程号杏;
3婴氮、輸入tweak的工程名稱Project Name: first
4、輸入deb包的名字盾致,Package Name: com.yahibo.first
5主经、輸入tweak作者的名稱,Author: yahibo
6庭惜、輸入作用對象的bundle identifier: com.apple.springboard
7罩驻、安裝完成后需要重啟應用,以進程名表示 命令:使用空格
項目創(chuàng)建完成如下:

create.png

8护赊、修改Tweak.xm文件

%hook SpringBoard

-(void)applicationDidFinishLaunching:(id)application{
    %orig;
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"我來了惠遏,哈哈哈" delegate:nil cancelButtonTitle:@"不見" otherButtonTitles:@"好的", nil];
    [alert show];
}

%end

9、修改Makefile文件骏啰,指定設備IP节吮,指定處理器架構,指定SDK版本器一,導入framework课锌,多個framework 空格添加。

THEOS_DEVICE_IP = 192.168.0.105
ARCHS = armv7 arm64
TARGET = iphone:latest:8.0
    
include $(THEOS)/makefiles/common.mk

TWEAK_NAME = first
first_FILES = Tweak.xm
first_FRAMEWORKS = UIKit

include $(THEOS_MAKE_PATH)/tweak.mk

after-install::
    install.exec "killall -9 SpringBoard"

10祈秕、配置完后終端進入工程文件執(zhí)行安裝命令:

make package install

執(zhí)行如下:

install.png

手機端顯示如下:

iphone.png

以上大功告成,完成了鎖屏狀態(tài)下加彈框雏胃。

11请毛、工程被打包到:./packages/com.yahibo.first_0.0.1-23+debug_iphoneos-arm.deb中,可使用dpkg 查看deb包信息:

dpkg -I ./packages/com.yahibo.first_0.0.1-23+debug_iphoneos-arm.deb

12瞭亮、在Cydia應用中搜索syslogd to/var/log/syslog并安裝方仿;搜索Core Utilities并安裝,安裝后可以使用tail命令查看文件统翩。
13仙蚜、項目打包成一個.dylib動態(tài)庫在越獄手機/Library/MobileSubstrate/DynamicLibraries/目錄下。

修改內容需要清除包

make clean
rm -rf packages

重啟SpringBoard殺死進程會自動重啟

killall -9 SpringBoard

卸載動態(tài)庫:

make package uninstall

二厂汗、常用的Logos語法簡介

1委粉、%hook指定需要hook的類名,以%end結尾娶桦。

%hook SpringBoard

-(void)applicationDidFinishLaunching:(id)application{
    %orig;//執(zhí)行原始操作
    UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"提示" message:@"我來了贾节,哈哈哈" delegate:nil cancelButtonTitle:@"不見" otherButtonTitles:@"好的", nil];
    [alert show];
}

%end

示例代碼為鉤住SpringBoard類的applicationDidFinishLaunching函數汁汗,先執(zhí)行原始操作,再顯示彈框栗涂。

2知牌、%log用來打印log的,將信息輸入到syslog中,格式%log([(<type><expr>斤程,...)])角寸。

%hook SpringBoard
-(void)applicationDidFinishLaunching:(id)application{
    %orig;//執(zhí)行原始操作
    %log((NSString *)@"iOSRE",(NSString *)@"Debug");
}
%end

3、%orig執(zhí)行被hook函數的原始代碼忿墅,類似于super.method功能扁藕,如果去掉,原始代碼不會執(zhí)行球匕。還可以使用該函數更改原始函數的參數:

%hook SBLockScreenDateViewController
-(void)setCustomSubtitleText:(id)arg1 withColor:(id)arg2{
    %orig(@"hello I am hibo",arg2);
}
%end

4纹磺、%group該指令用于%hook的分組,%group后邊跟的是組名亮曹,%group也是必須以%end結尾橄杨,其中可以包含多個%hook

5照卦、%init該指令用來初始化某個%group式矫,一個group只有被初始化后才可生效,init必須在hook中進行執(zhí)行役耕。

6采转、%ctor tweak的構造器,用來初始化瞬痘,如果不顯式定義故慈,Theos就會自動生成一個%ctor,并在其中調用%init(_ungrouped).如:%ctor { %init(_ungrouped)}

7框全、%new該指令用來給現(xiàn)有的class添加一個新的函數察绷。與Runtime中的class_addMethod相同。

8津辩、%c該指令用來獲取一個類的名稱拆撼,類似于objc_getClass

三喘沿、遇到的問題

1闸度、編譯報錯

"_OBJC_CLASS_$_UIApplication", referenced from: objc-class-ref in Tweak.x.a7a9a55a.o
  • Makefile文件中引入UIKit動態(tài)庫:xxx_FRAMEWORKS = UIKitxxx工程名稱

從越獄手機中我們可以拿到蘋果設備的桌面程序SpringBoard.app蚜印,砸殼后獲取到SpringBoard對應的頭文件莺禁。根據頭文件我們可以大致猜測到類及類方法的作用,因此使用以上方法晒哄,我們也可以更改其他一些顯示睁宰,修改桌面時間文本肪获、顏色、電池狀態(tài)柒傻、電量孝赫,當然這些可能沒有實用價值,我們只是通過這種方式來進一步了解逆向红符。
蘋果設備桌面頭文件

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末青柄,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子预侯,更是在濱河造成了極大的恐慌致开,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,290評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件萎馅,死亡現(xiàn)場離奇詭異双戳,居然都是意外死亡,警方通過查閱死者的電腦和手機糜芳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評論 2 385
  • 文/潘曉璐 我一進店門飒货,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人峭竣,你說我怎么就攤上這事塘辅。” “怎么了皆撩?”我有些...
    開封第一講書人閱讀 156,872評論 0 347
  • 文/不壞的土叔 我叫張陵扣墩,是天一觀的道長。 經常有香客問我扛吞,道長呻惕,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評論 1 283
  • 正文 為了忘掉前任滥比,我火速辦了婚禮蟆融,結果婚禮上,老公的妹妹穿的比我還像新娘守呜。我一直安慰自己,他們只是感情好山憨,可當我...
    茶點故事閱讀 65,453評論 6 385
  • 文/花漫 我一把揭開白布查乒。 她就那樣靜靜地躺著,像睡著了一般郁竟。 火紅的嫁衣襯著肌膚如雪玛迄。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,784評論 1 290
  • 那天棚亩,我揣著相機與錄音蓖议,去河邊找鬼虏杰。 笑死,一個胖子當著我的面吹牛勒虾,可吹牛的內容都是我干的纺阔。 我是一名探鬼主播,決...
    沈念sama閱讀 38,927評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼修然,長吁一口氣:“原來是場噩夢啊……” “哼笛钝!你這毒婦竟也來了?” 一聲冷哼從身側響起愕宋,我...
    開封第一講書人閱讀 37,691評論 0 266
  • 序言:老撾萬榮一對情侶失蹤玻靡,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后中贝,有當地人在樹林里發(fā)現(xiàn)了一具尸體囤捻,經...
    沈念sama閱讀 44,137評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 36,472評論 2 326
  • 正文 我和宋清朗相戀三年邻寿,在試婚紗的時候發(fā)現(xiàn)自己被綠了蝎土。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,622評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡老厌,死狀恐怖瘟则,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情枝秤,我是刑警寧澤醋拧,帶...
    沈念sama閱讀 34,289評論 4 329
  • 正文 年R本政府宣布,位于F島的核電站淀弹,受9級特大地震影響丹壕,放射性物質發(fā)生泄漏。R本人自食惡果不足惜薇溃,卻給世界環(huán)境...
    茶點故事閱讀 39,887評論 3 312
  • 文/蒙蒙 一菌赖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧沐序,春花似錦琉用、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至特姐,卻和暖如春晶丘,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工浅浮, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留沫浆,地道東北人。 一個月前我還...
    沈念sama閱讀 46,316評論 2 360
  • 正文 我出身青樓滚秩,卻偏偏與公主長得像专执,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子叔遂,可洞房花燭夜當晚...
    茶點故事閱讀 43,490評論 2 348