热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

iOS逆向工程(三):利用Cycript调试App

利用Cycript调试App一、Cycript是什么?Cycript是一种脚本语言,是Ob

利用Cycript调试App

一、Cycript是什么?
    1. Cycript是一种脚本语言,是Objective-C、Javascript、Java等语法的混合物,这就意味着我们可以在一条命令中使用这些语言的语法,甚至可以混合使用。(作者是Jay Freeman,没错,就是Cydia的作者,Jay Freeman出品必属精品,放心使用吧)
    1. Cycript可以用来调试、探索、修改正在运行的Mac/iOS App,只需要通过Cydia就可以安装Cycript了,然后就可以尽情的在iPhone上调试运行中的App了。
二、Cycript的用法
    1. 使用Cycript的前提是:Mac通过SSH远程登录到了iPhone,并且iPhone安装了Cycript脚本 (iPhone越狱后通过Cydia搜索安装)
    1. 想要调试某个App就需要知道此App的进程名称,在手机上打开想要调试的App,使用ps -A命令,列出来所有进程后,找到想要调试的APP的进程名即可。(例如:我们要调试皮皮虾App,在手机上打开皮皮虾,输入ps -A命令,找到皮皮虾的进程名称是Super,如下图所示)

      iOS逆向工程(三):利用Cycript调试App
      利用ps -A命令,列出来当前手机所有进程
    1. 选择某个进程进行挂载,挂载某个进程cycript -p 进程名称或者进程ID
    • 特别 特别 特别 要注意,这种挂载进程的方法只适用于iOS12之前的系统,iOS12及其以后的系统,要用另一种方法挂载,详情请看下面的第五章

例如:想挂载皮皮虾App,先让皮皮虾App在手机里跑起来,找到进程名后,输入以下命令 cycript -p Super

    1. 利用以上三步就可以挂载某个进程了,挂载之后,出现cy#,如下图所示,就意味着进入了Cycript脚本环境了,就可以输入Cycript语法来调试这个进程了

      iOS逆向工程(三):利用Cycript调试App
    1. cycript环境下的快捷键:
    • 退出:Ctrl + D
    • 清屏:Command + R
    • 取消输入:Ctrl + C
    1. 总结一下,其实非常简单

1>.使用前提:MacSSH登录了iPhone,iPhone安装了Cycript 2>.ps -A , 找出所有进程 3>.cycript -p Super,挂载皮皮虾,出现cy#,说明进入到了Cycript环境

三、Cycript的常用语法
    1. UIApp,就相当于OC中的[UIApplication sharedApplication]

      iOS逆向工程(三):利用Cycript调试App
    1. 定义变量var 变量名 = 变量值

      iOS逆向工程(三):利用Cycript调试App
    1. 用变量地址获取对象#内存地址,例如:#0x109703340,就拿到了这个地址的对象

      iOS逆向工程(三):利用Cycript调试App
    1. 查看对象的所有成员变量*对象,例如:*UIApp,就是拿到了UIApplication对象的所有变量

      iOS逆向工程(三):利用Cycript调试App
    1. 查看已经加载的所有OC类,ObjectiveC.classes
    1. 递归打印所有View的子控件,view.recursiveDescription().toString()
    1. 筛选出某种类型的对象choose(类型名称),例如choose(UIButton),找出所有UIButton类型的对象

      iOS逆向工程(三):利用Cycript调试App
    1. Cycript官方手册请点击这里
四、封装并导入Cycript库
    1. 大家是不是觉得上面的语法比较繁琐,用起来很不方便,我们可以把常用的语法封装进一个.cy文件中,以后直接用就可以了
    1. 例如把下面的代码,放到common.cy文件中 (大家仿照下面的代码写就可以了,exports参数是固定的,不需要改)

(function(exports){ // app id AppId = [NSBundle mainBundle].bundleIdentifier; // mainBundlePath BundlePath = [NSBundle mainBundle].bundlePath; // keyWindow KeyWin = function() { return UIApp.keyWindow; }; // rootView RootVc = function() { return UIApp.keyWindow.rootViewController; }; })(exports);

    1. 然后把封装好的.cy文件放到手机的/usr/lib/cycript0.9目录下
    1. 以后进入cycript环境后,首先导入封装好的cy文件,就可以使用封装好的方法了,命令是:@import xxx.cy
    1. MJ大佬封装好了一个.cy文件mjcript,大家可以去下载,放到手机的/usr/lib/cycript0.9目录下,以后再进入cycript环境后,只需要@import mjcript,就可以使用里面的方法了。如下图所示:

      iOS逆向工程(三):利用Cycript调试App
五、在iOS12及以后的系统,挂载进程的方法
    1. 在iOS12以后,使用cycript -p 进程名的方法挂载进程,就会报下面的错误:

assert($mach_task_self != NULL) *** _assert(status == 0):../Inject.cpp(143):InjectLibrary

    1. iOS12以后要使用cyrun挂载进程,进入cycript环境后,所有操作还跟以前一样
    1. cyrun安装方法:
    • (1). 通过Cydia安装New Curses、readline、adv-cmds、wgetwget主要为了在iPhone上可以下载deb文件)
    • (2). 以root账户登录到iPhone上,输入以下命令,下载以下deb文件

    wget http://apt.saurik.com/debs/cycript_0.9.594_iphoneos-arm.deb wget http://www.tateu.net/repo/files/net.tateu.cycriptlistenertweak_1.0.0_iphoneos-arm.deb wget http://www.tateu.net/repo/files/net.tateu.cyrun_1.0.5_iphoneos-arm.deb

    • (3). 输入以下命令,安装下载好的deb

    dpkg -i cycript_0.9.594_iphoneos-arm.deb dpkg -i net.tateu.cycriptlistenertweak_1.0.0_iphoneos-arm.deb net.tateu.cyrun_1.0.5_iphoneos-arm.deb

    1. 安装成功之后,以后想进入cycript环境,直接输入cyrun -n 进程名 -e -d -f或者cyrun -b bundleID -e命令就可以了,此命令会重启相应的进程,然后自动进入cycript环境
    1. 想退出的时候,按Control+D就可以退出cycript环境时,退出后会自动杀掉该进程
    1. 以皮皮虾APP为例,使用cyrun命令进入cycript环境,导入写好的mjcript库,查看皮皮虾APP的当前控制器和根控制器,如下图所示:

      iOS逆向工程(三):利用Cycript调试App
六、知识点总结

1>.使用Cycript调试APP的前提:用Mac以SSH的方式登录了iPhone,iPhone安装了Cycript 2>.ps -A , 找出所有进程,找到要调试的APP 3>.以皮皮虾APP为例,挂载皮皮虾APP的进程: - iOS12系统以前的挂载 :cycript -p Super - iOS12系统以后的挂载 :cyrun -n Super -e -d -f 或者 cyrun -b bundleID -e 4>. 挂载后,会进入cycript环境,导入封装好的库,使用其中的方法进行调试: @import mjcript 5>. 找到皮皮虾APP的当前控制器: MJFrontVc() 6>. 退出cycript环境:Control + D

七、修改皮皮虾APP界面
    1. 利用上述所学,来实际改一下皮皮虾APP的界面,将登录界面中的”登录”,改成”逆向调试”
    1. 流程如下:
    • 首先,SSH到iPhone:sh login.sh
    • 然后,挂载皮皮虾APP:cyrun -n Super -e -d -f
    • 然后,导入mjcipt库:@import mjcript
    • 然后,用手机打开皮皮虾的登录界面
    • 然后,查看登录界面的控制器:MJFrontVc()
    • 然后,查看登录界面的View的层级结构:MJVcSubviews(#0x107b0f400)
    • 然后,输入”登录”,查看”登录“的unicode编码
    • 然后,搜索”登录“的unicode编码,找到登录所属的UILabel对象
    • 然后,修改此UILabel的text属性:#0x117917e10.text = '逆向调试'
    • 然后, 修改此UILabel的size属性:#0x117917e10.size = MJSizeMake(200,30)
    • 最后,Control+D退出cycript环境
    1. 所有代码如下:

songpengdeMBP:~ songpeng$ sh login.sh iPhone7ceshiji:~ root# cyrun -n Super -e -d -f applicationName: Super is not running (-1) executableName: Super bundleIdentifier: com.bd.iphone.super Cycript is inactive: Device is not passcode locked Tweak Mode Waiting for Cycript to become active... Successfully enabled, you may now run cycript -r 127.0.0.1:8556 cy# @import mjcript {} cy# MJFrontVc() #"" cy# MJVcSubviews(#0x107b0f400) `; layer = > | > | | > | | | > | | | | > | | | > | | | | > | | | > | | | | (layer) | > | | (layer) | ; layer = > | | > | | | (layer) | | ; layer = ; contentOffset: {0, 0}; contentSize: {309, 42}; adjustedContentInset: {0, 0, 0, 0}> | | | > | | | | > | | | | | > | > | > | | > | | > | | | (layer) | > | | (layer) | > | | (layer) | > | | ; layer = > | | | > | | > | | | (layer) | > | | (layer) | > | | > | | | > | | ; layer = > | | | (layer) | > | | > | > | | > | | | > | | | | > | | | > | | | | (layer)` cy# 登录 throw new ReferenceError("Can't find variable: u767bu5f55") cy# #0x117917e10.text = '逆向调试' "u9006u5411u8c03u8bd5" cy# #0x117917e10.size = MJSizeMake(200,30) {0:200,1:30}

    1. 效果图如下:

      iOS逆向工程(三):利用Cycript调试App
      皮皮虾APP,逆向调试

推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • 树莓派Linux基础(一):查看文件系统的命令行操作
    本文介绍了在树莓派上通过SSH服务使用命令行查看文件系统的操作,包括cd命令用于变更目录、pwd命令用于显示当前目录位置、ls命令用于显示文件和目录列表。详细讲解了这些命令的使用方法和注意事项。 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • XML介绍与使用的概述及标签规则
    本文介绍了XML的基本概念和用途,包括XML的可扩展性和标签的自定义特性。同时还详细解释了XML标签的规则,包括标签的尖括号和合法标识符的组成,标签必须成对出现的原则以及特殊标签的使用方法。通过本文的阅读,读者可以对XML的基本知识有一个全面的了解。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
author-avatar
茨冈人686
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有