iOS 逆向编程(十五)Cycript 语法进阶(封装 .cy 脚本文件)

简介: iOS 逆向编程(十五)Cycript 语法进阶(封装 .cy 脚本文件)

一、简介

  • 每次进入 Cycript 调试之后,需要敲很多的调试指令,其实这些指令也是可以封装成 .cy脚本文件,然后引用进行使用。
  • 只要安装了Cycript在越狱的手机上就会有这个cycript文件夹,我们可以通过iFunBox查看,或者通过终端连接手机进行查看:
  • iFunBox 查看 cycript 文件夹

  • 终端连接手机查看 cycript 文件夹
iPhone:~ root# cd /usr/lib/cycript0.9
iPhone:/usr/lib/cycript0.9 root# ls
com/  org/
  • (单脚本文件)之后编写好的 .cy 脚本文件就只需要放到 cycript0.9 文件夹里面即可,可以通过之前写的 远程拷贝 方式传过去,或者通过 iFunBox 直接拖入也是可以的,然后通过 @import xxx 指令引入使用。
  • (很多脚本文件)上面这种存放脚本文件只是一种快捷方式,但是当你有很多的脚本文件的时候,更好的是存放到 com 文件夹里面,你打开上面的 com 文件夹,其实里面也就是作者存放自己 .xy 文件的地方,我们可以在里面自己建一个文件夹用来存放自己的 .cy 文件,但是导入方式会稍微有点差别,文章底部会有写这种导入方式的使用,简单测试可以使用上面的方式也是可以的。

二、封装案例

  • 新建一个 test.cy 文件,里面可以 JSOCC++ … 写法
  • 下面就是 JSOC 混搭写的,有 加减方法属性通过OC获取到的BundleID
(function(exports) {
  exports.age = 10;
  exports.sum = function (a, b) {
    return a + b;
  };
  exports.minus = function (a, b) {
    return a - b;
  };
  exports.appID = [NSBundle mainBundle].bundleIdentifier;
  exports.rootVC = function () {
    return UIApp.keyWindow.rootViewController;
  }
})(exports)
  • exports 你可以理解它是一个运行过程中传入进来的对象,你现在需要往这个对象身上添加一些属性或者方法。
  • 然后通过 远程拷贝 或者 iFunBox 拖入的方式放到手机 /usr/lib/cycript0.9 文件夹里面
dengzemiaodeMacBook-Pro:~ dengzemiao$ scp -P 10010 /Users/dengzemiao/Desktop/Project/ios/video/test/test.cy root@localhost:/usr/lib/cycript0.9
test.cy                                       100%  126    45.1KB/s   00:00    
dengzemiaodeMacBook-Pro:~ dengzemiao$ 
  • 然后进入 Cycript 调试模式,通过 @import test 引入进行使用
dengzemiaodeMacBook-Pro:ssh dengzemiao$ sh login.sh
iPhone:~ root# sycript -p neteasemusic
// 说明引入成功cy# @import test
cy# @import test
{age:10,sum:function (t,e){return t+e},minus:function (t,e){return t-e},appID:@"com.netease.cloudmusic",rootVC:function (){return UIApp.keyWindow.rootViewController}}
// 说明引入成功,只是属性没有设置上去
cy# @import test
{}
// 使用自定义方法,通过类的点语法使用
cy# test.sum(1,2)
3
cy# test.age
10
cy# test.appID
@"com.netease.cloudmusic"
cy# test.rootVC()
#"<NMRootNavigationController: 0x12a97e200>"
  • 如果报错如下:
cy# @import test
[1322] _krncall(task_for_pid) =5
[1322] MachObject.cpp[108]: _krncall(task_info) =10000003
[1322] DarwinInjector.cpp[73]: _assert(MSGetTaskInfo(info, task))[DarwinInjector.cpp:73]
*** _assert(status == 0):../Inject.cpp(143):InjectLibrary
  • 解决方案:
    1、删除之前导入到手机的 test.cy 文件,重新导入进来 (其实也是可以不删除直接覆盖的,但是我这里覆盖之后还是存在缓存问题,只好通过删除来避免,后面测了覆盖也是没问题,可能是哪里写错了,总之覆盖不行则可以通过删除重新上传来试试)
    2、退出手机调试的 APP,重新打开 (因为不重启,之前旧的 test.cy 可能会存在缓存文件,无法清除)
    3、退出 Cycript 调试模式,等 APP 重新打开之后重新进入调试模式。
    4、再次使用 @import test
  • 注意:如果有修改脚本文件,或者脚本文件有 bug 调整之后重新传入到手机,都需要按上面的步骤走一遍。

三、全局函数与属性

  • 上面都是对象属性的方式使用,@import test 导入之后需要通过 test.xxx 的方式去使用。
  • 那么怎么定义 全局函数或属性,只需要导入之后,不需要通过 点语法 直接使用呢,很简单,只需要去掉前面的 exports. 直接写方法或者属性名即可。
(function(exports) {
  age = 10;
  sum = function (a, b) {
    return a + b;
  };
  minus = function (a, b) {
    return a - b;
  };
  appID = [NSBundle mainBundle].bundleIdentifier;
  rootVC = function () {
    return UIApp.keyWindow.rootViewController;
  }
})(exports)
// 进入调试
iPhone:~ root# cycript -p neteasemusic
// 导入之后,全局属性是不会在对象 json 里面的,所以是空 json
// 如果上面其中有属性使用了 exports.age = 10,下面 json 就会有 age 这个字段
cy# @import test
{}
// 直接使用,不需要点语法
cy# sum
function (t,e){return t+e}
cy# minus
function (t,e){return t-e}
cy# age
10
cy# appID
@"com.netease.cloudmusic"
  • 注意:修改文件之后,需要按上面的步骤重新走一遍,如果没有达到效果就删除一下 test.cy 文件在重新导入一下,有时候缓存清除可能有延迟,APP调试模式 记得都重启重连漏一个都会有问题。

四、将脚本文件存放 com 目录(如果你有很多脚本文件的时候,用这种方式会更好管理)

  • 上面写的都是直接在cycript0.9根目录存放脚本文件,在这个文件夹下的可以直接通过@import test进行导入,那如果我们将test.cy文件放到com文件夹下的自定义文件夹dzm里面怎么导入?
  • 之前路径: cycript0.9 > test.cy
  • 现在路径: cycript0.9 > com > dzm > test.cy
  • 通过 手机终端命令行 或者 iFunBox/usr/lib/cycript0.9/com 文件下新建 dzm 文件夹。
iPhone:~ root# cd /usr/lib/cycript0.9/com
iPhone:/usr/lib/cycript0.9/com root# mkdir dzm
iPhone:/usr/lib/cycript0.9/com root# ls
dzm/  saurik/
  • 电脑端上传命令就需要调整一下路径了,之前是 /usr/lib/cycript0.9 文件夹,现在需要换成 /usr/lib/cycript0.9/com/dzm 了:
$ scp -P 10010 /Users/dengzemiao/Desktop/Project/ios/video/test/test.cy root@localhost:/usr/lib/cycript0.9/com/dz
  • 上传完成之后,导入也简单,使用跟之前一样,唯一区别就是导入变化了 @import com.dzm.test
// 进入调试
iPhone:~ root# cycript -p neteasemusic
// 导入脚本
cy# @import com.dzm.test
{}
// 使用还是跟之前一样
cy# appID
@"com.netease.cloudmusic"
cy# age
10
cy# 


相关文章
|
3月前
|
API Android开发 iOS开发
深入探索Android与iOS的多线程编程差异
在移动应用开发领域,多线程编程是提高应用性能和响应性的关键。本文将对比分析Android和iOS两大平台在多线程处理上的不同实现机制,探讨它们各自的优势与局限性,并通过实例展示如何在这两个平台上进行有效的多线程编程。通过深入了解这些差异,开发者可以更好地选择适合自己项目需求的技术和策略,从而优化应用的性能和用户体验。
|
5月前
|
Swift iOS开发 UED
揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【9月更文挑战第5天】本文通过具体案例介绍如何在iOS应用中使用Swift与UIKit实现自定义按钮动画,当用户点击按钮时,按钮将从圆形变为椭圆形并从蓝色渐变到绿色,释放后恢复原状。文中详细展示了代码实现过程及动画平滑过渡的技巧,帮助读者提升应用的视觉体验与特色。
87 11
|
6月前
|
Swift iOS开发 UED
【绝妙创意】颠覆你的视觉体验!揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【8月更文挑战第13天】本文通过一个具体案例,介绍如何使用Swift与UIKit在iOS应用中创建独特的按钮动画效果。当按钮被按下时,其形状从圆形变化为椭圆形,颜色则从蓝色渐变为绿色;释放后,动画反向恢复原状。利用UIView动画方法及弹簧动画效果,实现了平滑自然的过渡。通过调整参数,开发者可以进一步优化动画体验,增强应用的互动性和视觉吸引力。
74 7
|
6月前
|
安全 测试技术 调度
iOS开发-多线程编程
【8月更文挑战第12天】在iOS开发中,属性的内存管理至关重要,直接影响应用性能与稳定性。主要策略包括:`strong`(强引用),保持对象不被释放;`weak`(弱引用),不保持对象,有助于避免循环引用;`assign`(赋值),适用于基本数据类型及非指针对象类型;`copy`(复制),复制对象而非引用,确保不变性。内存管理基于引用计数,利用自动引用计数(ARC)自动管理对象生命周期。此外,需注意避免循环引用,特别是在block中。最佳实践包括理解各策略、避免不必要的强引用、及时释放不再使用的对象、注意block中的内存管理,并使用工具进行内存分析。正确管理内存能显著提升应用质量。
|
7月前
|
IDE 开发工具 Android开发
安卓与iOS开发环境对比分析:选择适合自己的编程平台
移动应用开发的两大阵营——安卓和iOS,各自拥有不同的开发环境和工具集。本文通过深入比较这两个平台的编程语言、集成开发环境(IDE)、用户界面设计、测试框架以及部署流程,旨在为开发者提供一个全面的视角来选择最符合个人或项目需求的开发环境。
|
1月前
|
iOS开发 开发者
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
141 67
uniapp开发ios打包Error code = -5000 Error message: Error: certificate file(p12) import failed!报错问题如何解决
|
3月前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
2天前
|
JavaScript 搜索推荐 Android开发
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
22 8
【01】仿站技术之python技术,看完学会再也不用去购买收费工具了-用python扒一个app下载落地页-包括安卓android下载(简单)-ios苹果plist下载(稍微麻烦一丢丢)-客户的麻将软件需要下载落地页并且要做搜索引擎推广-本文用python语言快速开发爬取落地页下载-优雅草卓伊凡
|
2月前
|
iOS开发 开发者 MacOS
深入探索iOS开发中的SwiftUI框架
【10月更文挑战第21天】 本文将带领读者深入了解Apple最新推出的SwiftUI框架,这一革命性的用户界面构建工具为iOS开发者提供了一种声明式、高效且直观的方式来创建复杂的用户界面。通过分析SwiftUI的核心概念、主要特性以及在实际项目中的应用示例,我们将展示如何利用SwiftUI简化UI代码,提高开发效率,并保持应用程序的高性能和响应性。无论你是iOS开发的新手还是有经验的开发者,本文都将为你提供宝贵的见解和实用的指导。
143 66

热门文章

最新文章