iOS 逆向编程(十六)DZMCycript 脚本使用(封装了常用的快捷函数,后续会继续添加)

  • 上一篇文章 已经说完怎么封装使用 .cy 脚本文件了,这里借鉴 MJ大佬 的阳光普照封装了一些常用的操作,可以帮助快速的分析软件,后续会在这基础上继续更新脚本。

  • 脚本里面都有注释,可以下载自己去看看,下面会安装使用一下其中的部分方法,其他的方法也就是大同小异,可以自己参考或者自己编写了。

  • 其实会了都不难,也就是 JS + OC,会 前端iOS开发 都能写得出来,后面可以加入一些有难度点的东西。

一、安装使用脚本

1、下载 DZMCycript 脚本文件

2、通过 手机终端命令 或者 iFunBox 导入到手机端的 /usr/lib/cycript0.9 里面,可以看 上一篇文章 怎么使用 .cy 脚本文件的。

$ scp -P 10010 /Users/dengzemiao/Desktop/GitHub/DZMCycript/DZMCycript.cy root@localhost:/usr/lib/cycript0.9

3、文件导入到手机之后,进入手机终端,之前文章有封装 SSH 免密登录的

dengzemiaodeMacBook-Pro:ssh dengzemiao$ sh login.sh
iPhone:~ root#

4、通过 Cycript 监听软件进入调试环境,并导入 DZMCycript 脚本

// 监听进入调试环境
iPhone:~ root# sycript -p neteasemusic

// 导入脚本成功
cy# @import DZMCycript
{}

// 使用脚本
cy# DZMAppId
@"com.netease.cloudmusic"

cy# DZMFrontVc()
#"<NMSettingTabViewController: 0x118a337a0>"

下面都是介绍一些方法的使用,会用可以不用看!!!。


二、DZMFrontVc() DZMRectMake(x, y, w, h) 测试:在任意APP上添加UI视图
// 进入软件监听调试环境
iPhone:~ root# cycript -p neteasemusic

// 导入 DZMCycript
cy# @import DZMCycript
{}

// 获取当前最上层控制器(如果有控制器嵌套什么的这个需要自己注意,可以通过脚本里面或者自己 iOS 的代码获取到当前控制器,如果不嵌套一般都是可以正常获取到的)
cy# DZMFrontVc()
#"<NMPhoneLoginViewController: 0x10a968340>"

// 添加一个红色 View 到软件页面上
// 创建 redView
cy# var redView = [[UIView alloc] initWithFrame:DZMRectMake(50, 50, 100, 100)]
#"<UIView: 0x114f3bef0; frame = (50 50; 100 100); layer = <CALayer: 0x280c718c0>>"

// 设置颜色
cy# redView.backgroundColor = [UIColor redColor]
#"UIExtendedSRGBColorSpace 1 0 0 1"

// 添加到当前控制器 View 上显示
cy# [#0x10a968340.view addSubview: redView]

三、DZMLoadFramework(name) 测试:动态给软件添加系统库
  • 比如我们要给一个 APP 添加上地图,但是 APP 没有导入地图库 MapKit.framework,那么也就不能使用地图对象 MKMapView 去创建地图,如果不导入库直接创建使用地图对象会报错的。

  • 通过 DZMCycript 脚本动态导入库,并使用,其实跟 iOS 开发是一样的

// 进入软件监听调试环境
iPhone:~ root# cycript -p neteasemusic

// 导入 DZMCycript
cy# @import DZMCycript
{}

// 获取当前控制器
cy# DZMFrontVc()
#"<NMPhoneLoginViewController: 0x1121d5d20>"

// 导入 MapKit 库,字符串即可
cy# DZMLoadFramework('MapKit')
#"NSBundle </System/Library/Frameworks/MapKit.framework> (loaded)"

// 创建 MapView
cy# var mapView = [[MKMapView alloc] initWithFrame: DZMRectMake(50, 50, 100, 100)]
#"<MKMapView: 0x10b3c5c00; frame = (50 50; 100 100); clipsToBounds = YES; layer = <CALayer: 0x280cd9c20>>"

// 添加到当前控制器 View 上显示地图
cy# [#0x1121d5d20.view addSubview: mapView]

四、DZMInstanceMethodNames(className, reg) 测试:获取指定对象里面有哪些对象方法,这样我们就可以拿到任何对象里面的方法,这样不就可以随便手动调用了
// 获得当前控制器 登录控制器
cy# DZMFrontVc()
#"<NMPhoneLoginViewController: 0x1121d5d20>"

// 获取登录控制器有哪些对象方法
cy# DZMInstanceMethodNames(#0x1121d5d20)
[&"backAction:",&"pageName",&"notNeedShowShareMenu",&"loginView",&"stopActivityWithText:",&"onResetPhoneClicked:",&"captchaDidChanged:",&"onCaptchaReturn",&"onEditPhoneButtonDidClicked:",&"setLoginView:",&"captchaView",&"setCurrentPhoneNumberExist:",&"setCurrentPhoneNumberNickname:",&"setCaptchaView:",&"_passwordLoginButtonDidClicked:",&"currentPhoneNumberExist",&"setIsVerifyingCaptcha:",&"_dismissCapthcaView:",&"currentPhoneNumberNickname",&"phoneNumberViewNextButtonClicked:",&"phoneNumberViewTextDidChanged:",&"resendButtonClicked:",&"isVerifyingCaptcha",&"startActivity",&"init",&"dealloc",&".cxx_destruct",&"viewWillAppear:",&"viewWillDisappear:",&"viewDidLoad",&"viewDidAppear:",&"shouldAutorotateToInterfaceOrientation:"]

  • 可以看到里面的 返回事件登录事件声明周期函数 … 都拿到了,拿到之后则可以手动调用了,对象调用方法属性不用教了吧。
// 也支持正则表达式过滤,怎么使用正则筛选取决于你的正则使用水平了
cy# DZMInstanceMethodNames(#0x1121d5d20, /Click/)
[&"onResetPhoneClicked:",&"onEditPhoneButtonDidClicked:",&"_passwordLoginButtonDidClicked:",&"phoneNumberViewNextButtonClicked:",&"resendButtonClicked:"]

五、DZMIvarNames(obj, reg) 测试:获取对象的所有成员变量名称
// 也支持正则表达式过滤,怎么使用正则筛选取决于你的正则使用水平了
cy# DZMIvarNames(#0x1121d5d20)

// 同样支持正则匹配
cy# DZMIvarNames(#0x1121d5d20, /view/)
六、DZMSublasses(className, reg) 测试:输出指定类型的所有子类,也就是继承这个指定类的所有类列出来
// 列出所有继承 UIViewController 的控制器
cy# DZMSublasses(UIViewController)

// 列出所有继承 UINavgationController 的控制器,看有没有自定义导航栏
cy# DZMSublasses(UINavgationController)

// 这样可以帮助快速排查找到一些类或者控制器,缩小范围
....
七、DZMChildVcs(vc) 测试:获取指定控制器里面的所有子控制器,还要其他获取子视图的方法就自己去试试了,例如 DZMSubviews(view)
// 获取根控制器里面的所有子控制器
cy# DZMChildVcs(DZMRootVc())

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡尔特斯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值