在逆向开发中,我需要使用到Logos语法,便于我们逆向开发
Logos语法
- 1.新建Logos测试工程
data:image/s3,"s3://crabby-images/da943/da94328a246690ade0d7fbc506c1d0cd57149b71" alt=""
data:image/s3,"s3://crabby-images/dbb20/dbb2005c7d5095a5bfd821cac6bb35017372f930" alt=""
- 2.找到Logos测试工程的可执行文件,并导出其中的头文件
$class-dump -H 001-LogosDemo -o /Users/yaoqi/Desktop/LogosHeaders
data:image/s3,"s3://crabby-images/30f57/30f57dd055f10f25175686bb4e371db6b73d3e74" alt=""
- 3.新建Monkey工程,将Logos测试工程重签名
data:image/s3,"s3://crabby-images/b78d0/b78d01bfa951275ea1b72027c5371382af5f26f3" alt=""
此时Monkey工程已经将libsubstrate.dylib库和RevealServer.framework库注入进去了,有了libsubstrate.dylib库就能写Logos语法了。
data:image/s3,"s3://crabby-images/6c2ad/6c2ad768de607d7ca9b06d5c2c712764b8e2314f" alt=""
- 4.在Monkey中的Logos文件夹的.xm文件写Logos语法
data:image/s3,"s3://crabby-images/ddd47/ddd47279bef80b141145bef195fc134c8060e00a" alt=""
Logos语法 | 功能解释 | 事例 |
---|---|---|
%hook | 需要hook哪个类 | %hook Classname |
%end | 代码块结束标记 | |
%group | 分组 | %group Groupname |
%new | 添加新方法 | %new(signature) |
%ctor | 构造函数 | %ctor { … }" |
%dtor | 析构函数 | %dtor { … } |
%log | 输出打印 | %log; %log([(<type>)<expr>, …]); |
%orig | 保持原有方法 | %orig;%orig(arg1, …); |
_02_loginHookDemoDylib.xm
// See http://iphonedevwiki.net/index.php/Logos
#import <UIKit/UIKit.h>
@interface ViewController: UIViewController
- (void)presentViewController:(UIViewController *)viewControllerToPresent animated: (BOOL)flag completion:(void (^ __nullable)(void))completion NS_AVAILABLE_IOS(5_0);
+ (void)CL_classMethod;
@end
%hook ViewController
- (void)loginBtnClicked:(id)arg1 {
%log;
UIAlertController *alertVC = [UIAlertController alertControllerWithTitle:@"Hook成功了!!!" message:nil preferredStyle:(UIAlertControllerStyleAlert)];
[alertVC addAction:[UIAlertAction actionWithTitle:@"确定" style:(UIAlertActionStyleCancel) handler:nil]];
[self presentViewController:alertVC animated:YES completion:nil];
}
%new
- (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event {
[self.view endEditing:YES];
[self.class CL_classMethod];
}
%new
+ (void)CL_classMethod {
NSLog(@"这是一个类方法!!!");
}
%end
这里在ViewController中定义了一个方法presentViewController:animated:completion:,只是为了能编译通过,骗过Xcode编译器。
5、运行成功后,Monkey工程就能Hook到001-LogosDemo工程里面的loginBtnClicked:
data:image/s3,"s3://crabby-images/88c84/88c84717bb4cafa352c6c3504b0bcd8e0d9e5393" alt=""
Monkey工程注入FLEX库
- 1.在Monkey的Dylib动态库中注入FLEX库
在Monkey工程的根目录添加Podfile文件,Target为Monkey工程动态库的Target
# Uncomment the next line to define a global platform for your project
platform :ios, '9.0'
target '002-loginHookDemoDylib' do
use_frameworks!
pod 'FLEX'
end
- 2.界面展示
data:image/s3,"s3://crabby-images/ae60a/ae60a6166596b781a3ea1f010389757ba858f16d" alt=""
data:image/s3,"s3://crabby-images/3b836/3b8365cfb14130a7b1c65e871f25ba39048e3504" alt=""
网友评论