iOS逆向:Theos与Tweak进阶篇
2020-07-23 本文已影响0人
码小菜
data:image/s3,"s3://crabby-images/311f7/311f781c1470c5f632a5469d71d01e01c54926ba" alt=""
目录
一,实现原理
二,使用进阶
三,实战练习:皮皮搞笑
四,实战练习:腾讯视频
一,实现原理
1,编译,打包和安装
-
make
:将代码编译为动态库
data:image/s3,"s3://crabby-images/e38f3/e38f3e33eb486fe9199dcbd39b7741aefc08d5e0" alt=""
-
make package
:将动态库和plist
文件打包为deb
文件
data:image/s3,"s3://crabby-images/fe2f9/fe2f911f0de479ca3cc5b4867166aca980347003" alt=""
-
make install
:将deb
文件通过本机10010端口发送到iPhone上,然后通过Cydia
来安装
data:image/s3,"s3://crabby-images/38916/389164118538d04b6e6142f612a5a4c8c43d6169" alt=""
-
Cydia
会将deb
文件安装在/Library/MobileSubstrate/DynamicLibraries
目录下,该目录由Cydia Substrate
插件来管理的
data:image/s3,"s3://crabby-images/9f241/9f241c6ba82d900098ea587aa99893cc8d270b13" alt=""
2,加载
-
plist
文件中存放的是目标APP的bundleId
data:image/s3,"s3://crabby-images/698bc/698bc010078870ddc0411cff1d666baac29682dc" alt=""
- 当启动目标APP时,
Cydia Substrate
插件会根据plist
文件中的bundleId
加载对应的动态库
data:image/s3,"s3://crabby-images/d8c27/d8c27668548f6f58a734eab2a3478b4095277c13" alt=""
- 这种方式只是修改了内存中的代码,并没有修改可执行文件中的代码,所以每次启动目标APP都需要重新加载动态库
data:image/s3,"s3://crabby-images/9b904/9b904a4c4657bba1eb15f0e33f9ce6dafafc1bd0" alt=""
二,使用进阶
1,文件管理
- 位置
data:image/s3,"s3://crabby-images/8f105/8f1058e0cb04685a9b75eb331592f935428f3627" alt=""
- 路径
data:image/s3,"s3://crabby-images/898c0/898c04e72df4df2170534f08576bdab792ed261b" alt=""
- 导入
data:image/s3,"s3://crabby-images/2de94/2de94a3a041b60a6cfe02de6816b2cb4fe3f97dc" alt=""
- 使用
data:image/s3,"s3://crabby-images/acaf3/acaf3a561f6179ae99fc5c6d7258a9f462a4da1c" alt=""
- 结果(用
Xcode
查看)
data:image/s3,"s3://crabby-images/59b60/59b605d042d020a397bf25158db44eab42124f09" alt=""
2,版本号,序号和模式
- 版本号
data:image/s3,"s3://crabby-images/d9e2c/d9e2c63f35aed1d321d324e9ec763b337ec11926" alt=""
- 序号:每次
make package
会自动+1
data:image/s3,"s3://crabby-images/60c22/60c22782add882852b2753c8deb182ef1b21d1bc" alt=""
- 模式:debug(
make package
),release(make package debug=0
)
data:image/s3,"s3://crabby-images/ab03b/ab03b32a5f99e1c2454f4381a424f18b07a51e07" alt=""
- 结果
data:image/s3,"s3://crabby-images/07767/07767612e59ac1d77de08bce04d773c8acce8673" alt=""
三,实战练习:皮皮搞笑
1,目标:移除首页广告
data:image/s3,"s3://crabby-images/ac9ba/ac9ba03d1e6f0383eb4f4c156e8a95272db164d1" alt=""
2,用MJAppTools查询APP基本信息
data:image/s3,"s3://crabby-images/83e19/83e19bf61ef19a3eb60d873e3eb3a6479ed567a9" alt=""
3,查询列表控件的地址
data:image/s3,"s3://crabby-images/86eba/86eba4d85fb5199537b2426d8fdd4d6f84718efc" alt=""
4,查询列表控件的数据源
data:image/s3,"s3://crabby-images/14db7/14db79419ee0fc01a99bff4025847b485185ff2d" alt=""
5,hook代码
%hook PPFeedPostADCell
// 移除数据
- (void)bindViewModel:(id)arg1 {
}
%end
%hook IGListAdapter
// 修改高度
- (struct CGSize)collectionView:(UICollectionView *)collectionView
layout:(id)arg2
sizeForItemAtIndexPath:(NSIndexPath *)indexPath {
UICollectionViewCell *cell = [collectionView cellForItemAtIndexPath:indexPath];
// %c表示获取class
if ([cell isKindOfClass:%c(PPFeedPostADCell)]) {
cell.backgroundColor = UIColor.redColor;
return CGSizeMake(UIScreen.mainScreen.bounds.size.width, 20);
}
return %orig;
}
%end
6,最终效果
data:image/s3,"s3://crabby-images/abfc3/abfc37c4effb3433943167a9829f5827321f75b3" alt=""
四,实战练习:腾讯视频
1,目标:移除视频广告
data:image/s3,"s3://crabby-images/ec485/ec485623735c81b067a9f8d570269aca6efbb3dd" alt=""
2,用frida-ios-dump进行脱壳
data:image/s3,"s3://crabby-images/66937/669372e70f53988f6dedb32d6858ad6278691eef" alt=""
3,用all_class_dump导出头文件
- 说明
1>
class_dump
只能导出可执行文件,有些APP会把代码封装成动态库,这样就会导致很多文件找不到
2>all_class_dump
能同时导出可执行文件和动态库
- 下载工具:
git clone https://github.com/QingangGit/all_class_dump.git
data:image/s3,"s3://crabby-images/4769e/4769ebb30d9a2e561710b22de198958003ccceb4" alt=""
- 在
all_class_dump.py
文件第一行加入:# coding:utf-8
data:image/s3,"s3://crabby-images/ea254/ea2548115357520e965ccc54c035815b0b4d48ae" alt=""
- 开始导出:
python [all_class_dump.py文件路径] [ipa包路径]
data:image/s3,"s3://crabby-images/f78dd/f78dd6cf702a9ebd6c5a96ee8a1602c693ee1a32" alt=""
- 导出的头文件存放在
dump_heads
文件夹中
data:image/s3,"s3://crabby-images/6d1ec/6d1ec1caafd05eb731961597890f418561f668f4" alt=""
4,查询相关控制器
data:image/s3,"s3://crabby-images/f0bb6/f0bb6809e3e995e870885e1025e651edb2ace2b8" alt=""
5,hook代码
// 方法在父类中
%hook QNBPlayerVideoAdsViewController
- (id)initWithEventProxy:(id)arg1
withPlayerInfo:(id)arg2
withParentViewController:(id)arg3
withPageViewController:(id)arg4
withAddToParenViewControllerNow:(_Bool)arg5 {
return nil;
}
- (id)initWithEventProxy:(id)arg1
withPlayerInfo:(id)arg2
withParentViewController:(id)arg3
withParentEventViewController:(id)arg4
withAddToParenViewControllerNow:(_Bool)arg5 {
return nil;
}
%end
%hook QADInteractAdBussinessVC
- (id)initWithCustomParentView:(id)arg1 {
return nil;
}
%end
%hook QADMobileNewVideoController
- (id)initWithScenesType:(long long)arg1 screenMode:(long long)arg2 {
return nil;
}
%end
6,最终效果
data:image/s3,"s3://crabby-images/4c7ea/4c7eafde6208c74fa21e23f7a92a49c701282300" alt=""