iOS逆向:Cycript
2020-06-13 本文已影响0人
码小菜
data:image/s3,"s3://crabby-images/16045/160453bb89778bb2f429c0fb2232d7325240ae06" alt=""
目录
一,基本知识
二,常用语法
三,mjcript
四,实战练习
五,Reveal
一,基本知识
1,概念
-
它是
Objective-C
、C++
、JavaScript
、Java
等语言的混合物 -
它可以用来调试、修改
Mac
或iPhone
上正在运行的APP -
需要通过
Cydia
安装Cycript
工具,才能调试iPhone上的APP(软件源:http://apt.saurik.com)
data:image/s3,"s3://crabby-images/94dbd/94dbd3d909bc997476602cef90aeded2ab6c9b22" alt=""
2,ps命令
-
process status
(进程状态)的缩写,可以列举出系统所有正在运行的进程 -
iPhone上需要通过
Cydia
安装adv-cmds
工具(软件源:http://apt.saurik.com)
data:image/s3,"s3://crabby-images/ba4a3/ba4a3e4bbf96f908fda1145de60ed81e538a5c5d" alt=""
- 所有进程:
ps –A
(打开喜马拉雅APP)
data:image/s3,"s3://crabby-images/c29aa/c29aaefb0bd9617963900a3efb831835558dab25" alt=""
data:image/s3,"s3://crabby-images/bfed4/bfed4fdb38d5778bf0c3ad64038ea95c4f2d0fb3" alt=""
- 搜索进程:
ps –A | grep 关键词
data:image/s3,"s3://crabby-images/88a99/88a996c5cf088be5f281e7738c5a11ec75b54cd6" alt=""
3,启动和退出
- 启动:
cycript -p 进程名称
- 退出:
control + d
- 清屏:
command + r
data:image/s3,"s3://crabby-images/c39f9/c39f91dc53fadec5896df289deac144cdabe1d81" alt=""
二,常用语法
1,UIApp
= UIApplication.sharedApplication()
data:image/s3,"s3://crabby-images/3ea31/3ea319784c9c7d8878f116cac04b154d2cf398ae" alt=""
2,定义变量:var 变量名 = 变量值
data:image/s3,"s3://crabby-images/60e45/60e45dc0d1a86cf3e97d24671eceb4639dbfe7e4" alt=""
3,定义函数:function 函数名(...) { ... }
data:image/s3,"s3://crabby-images/df5d5/df5d57a32205eba4534f4326c27ee7f32b10f7e8" alt=""
4,用内存地址获取对象:#内存地址
data:image/s3,"s3://crabby-images/ef53a/ef53a846506c898bfaa4d56366936fd954924925" alt=""
5,查看对象的所有成员变量:*对象
data:image/s3,"s3://crabby-images/81a3a/81a3a95d61e5f19f280b4e65ec5155cfe7c476aa" alt=""
6,递归打印view的所有子控件:view.recursiveDescription().toString()
data:image/s3,"s3://crabby-images/ed2b2/ed2b2cfe31663b2153419ecd20f6021d13fa36fd" alt=""
7,筛选出某种类型的对象:choose(类型)
data:image/s3,"s3://crabby-images/65bd3/65bd31d0120594f91ed19dcb296d135f1cbaffce" alt=""
三,mjcript
1,介绍
-
它是对
Cycript
的封装,提供了一些比较常用的函数
2,导入
- 将
mjcript.cy
文件拷贝到iPhone的/usr/lib/cycript0.9
目录下
data:image/s3,"s3://crabby-images/7f079/7f0792a41380f36dda62a616df6533cebbd22116" alt=""
data:image/s3,"s3://crabby-images/f5c22/f5c221320391e1e5c682fbac4d427b68d813cbf8" alt=""
- 进入
Cycript
环境,然后import
一下即可使用
data:image/s3,"s3://crabby-images/7da60/7da60df2fc5206dee96f59c073c2b709e614ae78" alt=""
3,常用函数
- 获取bundleId:
MJAppId
data:image/s3,"s3://crabby-images/b8eda/b8edab87284104050cfb87f45613be98f75df9a2" alt=""
- 获取documents路径:
MJDocPath
data:image/s3,"s3://crabby-images/5d978/5d9783ee6cbaa5475ea8108e8bae6598fee20896" alt=""
- 获取根控制器:
MJRootVc()
data:image/s3,"s3://crabby-images/0a5b9/0a5b9ccbcb610018801ec16df3ea1fecd23fd830" alt=""
- 获取当前显示的控制器:
MJFrontVc()
data:image/s3,"s3://crabby-images/5c656/5c6565874467f9f4750961a32506dba0c99e927d" alt=""
- 获取所有成员变量的名称:
MJIvarNames(...)
data:image/s3,"s3://crabby-images/5bfe7/5bfe733964775c4d3eb55d45aab6ed4115279305" alt=""
- 获取所有实例方法的名称:
MJInstanceMethodNames(...)
data:image/s3,"s3://crabby-images/6dc16/6dc16709963cb88003972938be613b12930f15a6" alt=""
- 获取controller的层级结构:
MJChildVcs(...)
data:image/s3,"s3://crabby-images/e645a/e645a07e7956fe1db4a48ff3a63392552cf0e8e8" alt=""
- 获取view的层级结构:
MJSubviews(...)
data:image/s3,"s3://crabby-images/0f2d6/0f2d606848e633e940b9fae7e8bcb62aab35487f" alt=""
- 根据关键词进行筛选
data:image/s3,"s3://crabby-images/1af7c/1af7c9ecedbf6a6b2a4019f2b3b14501008fbc51" alt=""
- 添加动态库:
MJLoadFramework(...)
data:image/s3,"s3://crabby-images/90683/90683bdc5661257ca788ebdb42372e0fdc05f103" alt=""
四,实战练习
1,利用python
打印字符
data:image/s3,"s3://crabby-images/97960/97960818308abf969cfb33ffa37d6d44cdb7d42b" alt=""
2,修改“立即登录”
- 查找
data:image/s3,"s3://crabby-images/b0d4f/b0d4fa31a19c4a663fa2bfa1cc11df09ac9883ce" alt=""
data:image/s3,"s3://crabby-images/526f6/526f686cb629a62a475b55bae9186b033f646116" alt=""
data:image/s3,"s3://crabby-images/5a983/5a983525ac614da058163d8343ead7fb34f3aa58" alt=""
- 修改
data:image/s3,"s3://crabby-images/a1f84/a1f843a4fed45c8c37099e61fd93d1367293035a" alt=""
- 效果
data:image/s3,"s3://crabby-images/47117/47117efe6a1f9da6eb1d2524dc288ebddde85a91" alt=""
3,移除“VIP会员”
- 查找
data:image/s3,"s3://crabby-images/09434/09434ff0e27f5ddd8fea135c472edeff62435451" alt=""
- 移除
data:image/s3,"s3://crabby-images/81547/815471c31f36cf74731d1b8588c50f7288c09bb7" alt=""
- 效果
data:image/s3,"s3://crabby-images/8219d/8219d40c60d380d9bc179b108f4f5c5d04ccea99" alt=""
4,添加“view”
- 添加
data:image/s3,"s3://crabby-images/05a80/05a8055261c96c3e4de9c19d126bf370c6057f30" alt=""
- 效果
data:image/s3,"s3://crabby-images/e89c2/e89c20a325e6e4c421e7fde7801d6ce6ec3e09a9" alt=""
5,调用“设置按钮点击方法”
- 查找
data:image/s3,"s3://crabby-images/69445/69445426ee6c4c4f3ce7d6e57d971154a17f0881" alt=""
- 调用
data:image/s3,"s3://crabby-images/6edc0/6edc0149bc57db69ca8cf39780962fb5a1c9cc5f" alt=""
- 效果
data:image/s3,"s3://crabby-images/868bf/868bf76b5d9ad3bca721516e83b599de611afea3" alt=""
五,Reveal
1,介绍
-
它是一款调试UI界面的神器
2,配置
- 在iPhone上通过
Cydia
安装Reveal Loader
工具(软件源:http://apt.thebigboss.org)
data:image/s3,"s3://crabby-images/4ee09/4ee096ce5da1af4f5b9890b951a5347d18b517a3" alt=""
- 在设置中打开需要调试的APP
data:image/s3,"s3://crabby-images/a81b5/a81b57764ffa4e025ed07836f060339b63f7f06e" alt=""
- 将iPhone上的
/Library/MobileSubstrate/DynamicLibraries/RHRevealLoader.dylib
替换为Mac上的~/RevealServer.framework/RevealServer
data:image/s3,"s3://crabby-images/8743c/8743c9ceb7cd549d4fd2f2b8a852d1c4af4b79bb" alt=""
- 重启iPhone(命令:
reboot
)和Reveal
data:image/s3,"s3://crabby-images/53e41/53e41758867557b6b75c59f5081434cad0e4ef48" alt=""
data:image/s3,"s3://crabby-images/4894f/4894f64b7f8860f0379883cfe8c0453c4c3faba3" alt=""