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

简介: 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())


相关文章
|
25天前
|
API Android开发 iOS开发
深入探索Android与iOS的多线程编程差异
在移动应用开发领域,多线程编程是提高应用性能和响应性的关键。本文将对比分析Android和iOS两大平台在多线程处理上的不同实现机制,探讨它们各自的优势与局限性,并通过实例展示如何在这两个平台上进行有效的多线程编程。通过深入了解这些差异,开发者可以更好地选择适合自己项目需求的技术和策略,从而优化应用的性能和用户体验。
|
7月前
|
存储 Android开发 iOS开发
iOS不支持HEIC格式的图片显示和标签函数显示问题及解决方案
iOS不支持HEIC格式的图片显示和标签函数显示问题及解决方案
233 0
|
3月前
|
Swift iOS开发 UED
揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【9月更文挑战第5天】本文通过具体案例介绍如何在iOS应用中使用Swift与UIKit实现自定义按钮动画,当用户点击按钮时,按钮将从圆形变为椭圆形并从蓝色渐变到绿色,释放后恢复原状。文中详细展示了代码实现过程及动画平滑过渡的技巧,帮助读者提升应用的视觉体验与特色。
69 11
|
4月前
|
Swift iOS开发 UED
【绝妙创意】颠覆你的视觉体验!揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【8月更文挑战第13天】本文通过一个具体案例,介绍如何使用Swift与UIKit在iOS应用中创建独特的按钮动画效果。当按钮被按下时,其形状从圆形变化为椭圆形,颜色则从蓝色渐变为绿色;释放后,动画反向恢复原状。利用UIView动画方法及弹簧动画效果,实现了平滑自然的过渡。通过调整参数,开发者可以进一步优化动画体验,增强应用的互动性和视觉吸引力。
60 7
|
4月前
|
安全 测试技术 调度
iOS开发-多线程编程
【8月更文挑战第12天】在iOS开发中,属性的内存管理至关重要,直接影响应用性能与稳定性。主要策略包括:`strong`(强引用),保持对象不被释放;`weak`(弱引用),不保持对象,有助于避免循环引用;`assign`(赋值),适用于基本数据类型及非指针对象类型;`copy`(复制),复制对象而非引用,确保不变性。内存管理基于引用计数,利用自动引用计数(ARC)自动管理对象生命周期。此外,需注意避免循环引用,特别是在block中。最佳实践包括理解各策略、避免不必要的强引用、及时释放不再使用的对象、注意block中的内存管理,并使用工具进行内存分析。正确管理内存能显著提升应用质量。
|
5月前
|
Swift iOS开发 Kotlin
苹果iOS新手开发之Swift中实现类似Kotlin的作用域函数
Swift可通过扩展实现类似Kotlin作用域函数效果。如自定义`let`, `run`, `with`, `apply`, `also`,增强代码可读性和简洁性。虽无直接内置支持,但利用Swift特性可达成相似功能。
78 7
|
5月前
|
移动开发 开发工具 Android开发
探索安卓与iOS开发的差异:平台特性与编程实践
【7月更文挑战第8天】在移动开发的广阔天地中,安卓和iOS这两大操作系统各自占据着半壁江山。它们在用户界面设计、系统架构及开发工具上展现出截然不同的特色。本文将深入探讨这两个平台在技术实现和开发生态上的关键差异,并分享一些实用的开发技巧,旨在为跨平台开发者提供有价值的见解和建议。
|
5月前
|
IDE 开发工具 Android开发
安卓与iOS开发环境对比分析:选择适合自己的编程平台
移动应用开发的两大阵营——安卓和iOS,各自拥有不同的开发环境和工具集。本文通过深入比较这两个平台的编程语言、集成开发环境(IDE)、用户界面设计、测试框架以及部署流程,旨在为开发者提供一个全面的视角来选择最符合个人或项目需求的开发环境。
|
6月前
|
安全 IDE Android开发
探索Android与iOS开发的差异:平台特性与编程实践
【6月更文挑战第17天】在移动应用开发的广阔天地中,Android和iOS两大平台各自占据半壁江山。它们在用户群体、系统架构以及开发环境上的差异,为开发者带来了不同的挑战和机遇。本文深入探讨了这两个平台在技术实现、界面设计、性能优化等方面的主要区别,并提供了实用的开发建议,旨在帮助开发者更好地理解各自平台的特性,从而创造出更加优秀的移动应用。
|
7月前
|
移动开发 Android开发 iOS开发
ios标准页面调用HTML5页面和HTML5调用ios的函数
ios标准页面调用HTML5页面和HTML5调用ios的函数
52 0