Logos 語法簡單介紹

準備工作

  1. 新建一個Demo 萌焰,類似登錄頁面总放,少許邏輯呈宇,導(dǎo)出 app 包 和 頭文件,以待備用局雄。
  2. 新建一個 MonkeyDev 項目甥啄,導(dǎo)入要 Hook 的 APP 包。

Cydia Substrate

Cydia Substrate 原名為 Mobile Substrate 炬搭,它的主要作用是針對OC方法蜈漓、C函數(shù)以及函數(shù)地址進行HOOK操作。當然它并不是僅僅針對iOS而設(shè)計的宫盔,安卓一樣可以用疆柔。官方地址:http://www.cydiasubstrate.com/

Cydia Substrate主要由3部分組成:

  • MobileHooker

    MobileHooker顧名思義用于HOOK损肛。它定義一系列的宏和函數(shù),底層調(diào)用objc的runtimefishhook來替換系統(tǒng)或者目標應(yīng)用的函數(shù).
    其中有兩個函數(shù):

    • MSHookMessageEx 主要作用于Objective-C方法
     void MSHookMessageEx(Class class, SEL selector, IMP replacement, IMP result)
    
    
    • MSHookFunction 主要作用于C和C++函數(shù)
     void MSHookFunction(voidfunction,void* replacement,void** p_original)
    
    

    Logos語法的%hook 就是對此函數(shù)做了一層封裝

Cydia Substrate 底層使用的就是 Method Swizzlefishhook

Cydia substrate 注入進去之后渠啊,就可以用 Logos 語法 來寫 Logos 了。

image.png
image.png

其中 _02_LoginHookDemoDylib.xm
x : 代表 這個文件支持 Logos 語法
如果后綴為 單獨的 x : 說明 源文件支持 Logos 的 C語言 語法余爆。
xm 支持 **Logos ** 的 C斋配,C++,OC 語法寄悯。

image.png
  • 文件擴展名
    .X 將由Logos處理萤衰,然后進行預(yù)處理并編譯為objective-c。
    .xm 將由Logos處理猜旬,然后進行預(yù)處理并編譯為objective-c ++腻菇。
    .xi 將首先作為objective-c進行預(yù)處理,然后Logos將處理結(jié)果昔馋,然后將進行編譯筹吐。
    .xmi 將首先作為objective-c ++進行預(yù)處理,然后Logos將處理結(jié)果秘遏,然后將進行編譯丘薛。

xi或xmi文件可以在#define宏中使用Logos指令。

Logos 語法介紹

  • %group
image.png
image.png
  • constructor 構(gòu)造函數(shù):多組 group 就需要 創(chuàng)建 constructor邦危。
// constructor 構(gòu)造函數(shù)
%ctor{
    %init(group1)%init(group2)
}

沒創(chuàng)建一個group 就需要 init洋侨,前后的初始化順序很重要舍扰,后面會把前面的 group 覆蓋掉。

可以判斷加載不同的group

  • %init 初始化
%ctor{
    NSString *version = [UIDevice currentDevice].systemVersion;
    if(version.doubleValue >= 11.4){
        %init(group1)
    }else{
        %init(group2)
    }
}

默認的會隱式加載
%ctor{
%init(_ungrouped)
}
如果不顯示定義希坚,Theos會自動生成一 個%ctor, 并在其中調(diào)用%init( ungrouped).
%ctor 一般可以用來初始化%group,以及進行 MSHookFunction 等操作边苹。

  • %dtor 析構(gòu)函數(shù),與 %ctor 對應(yīng)

  • %log 輸出裁僧,直接調(diào)用

image.png

%log;

002-LoginHookDemo/002-LoginHookDemoDylib/Logos/_02_LoginHookDemoDylib.xm:11?[m ?[0;30;46mDEBUG:?[m -[<ViewController: 0x105612cb0> btnClick:<UIButton: 0x1057156c0; frame = (164 318; 31 30); opaque = NO; autoresize = RM+BM; layer = <CALayer: 0x1c4229c40>>]

  • %orig
image.png

可以用來接收返回的值并修改个束,也可以傳入?yún)?shù)。

  • %new 給某個類添加方法

%new 直接添加聊疲,不需要 %end 結(jié)束茬底,另外 一個 %new 對應(yīng)一個方法。

如:

%new
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event
{
    [self.view  endEditing:YES];
}

%new
+ (void)class_Methiod
{
    NSLog(@"這是一個類方法");
}
image.png

上圖可以看出 MonkeyDev 原理也是注入的 動態(tài)庫获洲,可以在內(nèi)部新建你想創(chuàng)建的任何文件阱表,都會被打包進 動態(tài)庫中。

  • %c() 根據(jù)類名獲取一個類
image.png

如下贡珊,這樣調(diào)用一樣的效果:

    // 調(diào)用類方法
    // 1.
//    [self.class class_Methiod];
    // 2.
//    [NSClassFromString(@"ViewController") class_Methiod];
    // 3.
    [%c(ViewController) class_Methiod];

Logos 小練習(xí)

需求:在微信首頁左側(cè)添加一個按鈕實現(xiàn)和右側(cè)一樣的功能最爬。

  • 準備
    創(chuàng)建一個 MonkeyDev 項目,重簽名 WeChat门岔,編譯導(dǎo)出 WeChat 頭文件爱致。

class-dump -H WeChat -o /Users/username/Desktop/WeChatHeaders6.7.1

  • 運行,使用 Xcode 調(diào)試 固歪,使用 Debug View Hierarchy 查看視圖層次結(jié)構(gòu)蒜鸡,可以看到:
image.png

可以看出添加按鈕相應(yīng)方法是在 NewMainFrameRightTopMenuBtn 類的 showRightTopMenuBtn 方法;

首頁:NewMainFrameViewController

  • 編寫 Hook 代碼
%hook NewMainFrameViewController

- (void)viewDidLoad {
    %orig;
    NSLog(@"\n\n -----viewDidLoad------\n");
   // UIButton *leftBtn = [UIButton buttonWithType:UIButtonTypeContactAdd];
   // [leftBtn addTarget:self action:@selector(leftClick) forControlEvents:UIControlEventTouchUpInside];
  //  self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:leftBtn];

}

- (void)viewDidAppear:(BOOL)animated
{
    %orig;
    NSLog(@"\n\n ------ viewDidAppear --------\n\n");
    
    UIButton *leftBtn = [UIButton buttonWithType:UIButtonTypeContactAdd];
    [leftBtn addTarget:self action:@selector(leftClick) forControlEvents:UIControlEventTouchUpInside];
    self.navigationItem.leftBarButtonItem = [[UIBarButtonItem alloc] initWithCustomView:leftBtn];
}

%new
- (void)leftClick
{
    NSLog(@"自定義按鈕響應(yīng)了@紊选7攴馈!");
}


- (UIBarButtonItem *)navigationItem
{
    NSLog(@"\n\n------GetNavigationItem------\n\n");
    
    return %orig;
}

%orig 調(diào)用原來的方法蒲讯,相當于犯法交換忘朝,調(diào)用自己

添加的按鈕:

IMG_0037.PNG
  • 接著查找,右側(cè)按鈕調(diào)用的方法判帮,

鏈接 Cycript 調(diào)試局嘁,

image.png
image.png

小問題:

image.png

這個折磨了我許久,因為 WeChat 的首頁一直在連接中晦墙,Cycript 連接不上悦昵,重新?lián)Q一個手機就 OK了。

  • 修改 Hook 代碼

通過上面可以看出: 右側(cè)的彈窗按鈕調(diào)用的方法就是

[self.navigationItem.rightBarButtonItem.view showRightTopMenuBtn]

   //  從內(nèi)存中能查到調(diào)用該方法:[self.navigationItem.rightBarButtonItem.view showRightTopMenuBtn]
     self:代表NewMainFrameViewController控制器
[self.navigationItem.rightBarButtonItem.view showRightTopMenuBtn]

效果如圖:

IMG_9B63571FE907-1.jpeg
  • 修改Navigationbar標題:
- (void)viewDidAppear:(BOOL)animated
{
    %orig;
    NSLog(@"\n\n ------ viewDidAppear --------\n\n");
    
    // 修改Navbar標題
    UILabel *titleLb = [[UILabel alloc] initWithFrame:CGRectMake(0, 0, 100, 40)];
    titleLb.backgroundColor = [UIColor orangeColor];
    titleLb.text = @"??????Superman??????";
    
    self.navigationItem.titleView = titleLb;
}
IMG_A9FEADF342CB-1.jpeg
  • 修改Tabbar標題
    // 修改Tabbar標題
    NSArray *titlesArr = @[@"No1-6",@"No2-6",@"No3-6",@"No4-6"];
    NSArray<UITabBarItem *> *tabbarsArr = self.tabBarController.tabBar.items;
    
    for (int i =0; i < tabbarsArr.count; i++) {
        UITabBarItem *item = [tabbarsArr objectAtIndex:i];
        [item setTitle:[titlesArr objectAtIndex:i]];
    }
IMG_E50502A1909D-1.jpeg

修改你想修改的晌畅,能修改的但指!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子棋凳,更是在濱河造成了極大的恐慌拦坠,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件剩岳,死亡現(xiàn)場離奇詭異贞滨,居然都是意外死亡,警方通過查閱死者的電腦和手機拍棕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門晓铆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人莫湘,你說我怎么就攤上這事尤蒿≈F” “怎么了幅垮?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長尾组。 經(jīng)常有香客問我忙芒,道長,這世上最難降的妖魔是什么讳侨? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任呵萨,我火速辦了婚禮,結(jié)果婚禮上跨跨,老公的妹妹穿的比我還像新娘潮峦。我一直安慰自己,他們只是感情好勇婴,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布忱嘹。 她就那樣靜靜地躺著,像睡著了一般耕渴。 火紅的嫁衣襯著肌膚如雪拘悦。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天橱脸,我揣著相機與錄音础米,去河邊找鬼。 笑死添诉,一個胖子當著我的面吹牛屁桑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播栏赴,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼蘑斧,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起乌叶,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤盆偿,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后准浴,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體事扭,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年乐横,在試婚紗的時候發(fā)現(xiàn)自己被綠了求橄。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡葡公,死狀恐怖罐农,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情催什,我是刑警寧澤涵亏,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布,位于F島的核電站蒲凶,受9級特大地震影響气筋,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜旋圆,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一宠默、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧灵巧,春花似錦搀矫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至肄方,卻和暖如春冰垄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背权她。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工虹茶, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人隅要。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓蝴罪,卻偏偏與公主長得像,于是被迫代替她去往敵國和親步清。 傳聞我的和親對象是個殘疾皇子要门,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

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