iOS逆向编程第一篇:工具

一、前言

想要学习iOS逆向编程,没有几样工具怎么可以呢?当然可以不使用工具就能做逆向的大神可以无视跳过此文。
工欲善其事,必先利其器,我们先来介绍下接下来需要使用的工具,这些工具都会提高我们的学习以及Mac电脑的使用效率等等。
对于逆向编程的工具我们分为:1.常用工具。2.必备工具。

二、常用工具介绍以及安装配置

说明:常用工具并不是只为了学习iOS逆向编程而安装,在日常使用Mac电脑中也可以使用的工具。
好了,废话不多说了直接介绍工具的安装和配置。

1.Alfred 智能搜索软件
Alfred是一款方便的智能搜索软件,完全能替代OS X自带的Spotlight的软件,因为Spotlight有的功能它都涵盖,而且它还能处理Spotlight之外的事情,功能非常之强大。
目前最新版本为Alfred 3.2,它可以为你节省时间,搜索出所有你的请求,非常的快捷方便。Alfred可以帮助你快速、方便的打开任意应用程序,配合快捷键你可以大大提高工作效率。
软件下载具体安装和配置:Alfred工具安装教程

2.Go2Shell 软件
可以直接通过Go2ShellFinder中打开一个当前目录的终端窗口,不用再使用cd命令进入到当前Finder位置。
软件下载具体安装和配置:Go2Shell工具安装教程

3.iTerm2 终端利器
iTerm2Mac OS下最好的终端工具。不喜欢使用系统自带的Terminal的朋友,可以使用iTerm2来作为Terminal的替代品,它也是iTerm的继任者。它适用于macOS 10.10或更新版本的Mac OS系统。
软件下载具体安装和配置:iTerm2 工具安装教程

三、必备工具介绍以及安装配置

说明:必备工具是为了学习iOS逆向编程而安装的,当然不排除其他操作也需要使用到这些必备工具。

1.MonkeyDev
MonkeyDev是原有iOSOpenDev的升级,非越狱插件开发集成神器!它是Xcode的一个插件,在逆向编程中会使用到MonkeyDev插件进行创建工程。可以使用Xcode开发CaptainHook TweakLogos TweakCommand-line Tool,在越狱机器开发插件,这是原来iOSOpenDev功能的迁移和改进。只需拖入一个砸壳应用,自动集成class-dumprestore-symbolRevealCycript和注入的动态库并重签名安装到非越狱机器。既支持调试自己编写的动态库和第三方App。又支持通过CocoaPods第三方应用集成SDK以及非越狱插件,简单来说就是通过CocoaPods搭建了一个非越狱插件商店。
软件下载具体安装和配置:MonkeyDev 工具安装教程

2.Cycript
Cycript允许开发人员探讨和修改iOSMac OS X上运行的应用程序。Cycript是一个理解Objective-C语法的javascript解释器,它能够挂钩正在运行的进程,能够在运行时修改应用的很多东西。关于Cycript的命令在文章结尾处进行描述。
软件下载具体安装和配置:Cycript工具安装教程

Cycript命令

命令 效果
UIApp 获取当前App的Appdelegate对象
UIWindow.keyWindow 获取当前的keyWindow对象
var 定义一个对象
#+内存地址 得到当前内存地址的对象
*+对象 得到对象的所有成员变量
choose(UILabel) 查找当前界面的所有UILabel
四、创建一个iOS逆向编程的工程

创建一个iOS逆向编程的工程,进行调试和查看线上商店的App的结构。
具体步骤:

  • 1. 打开Xcode新建一个工程,选择MonkeyApp新建工程。
  • 2. 定位到TargetApp的路径下,将线上商店App的安装包拷贝到该目录下。
  • 3. 运行新工程到手机上,打开iTerm2终端。
  • 4. 执行命令cycript -r 192.168.31.178:6666,进入cycript模式。
  • 5. 使用Cycript命令进行查看线上商店的App的结构。

注意:192.168.31.178为真机的IP地址,6666为新工程中配置的端口号

五、创建一个脚本

创建脚本能节省我们在终端输入过长的命令。
具体步骤:

  • 1. 打开iTerm2终端,使用cd ~/Desktop命令定位到桌面。
  • 2. 使用vim login.sh命令创建一个脚本文件。
  • 3.login.sh脚本文件添加cycript -r 192.168.31.178:6666命令,保存并退出。
  • 4. 在用户目录下创建一个CustomShell文件夹并把login.sh也拷贝到该文件夹下。
  • 5. 打开iTerm2终端,使用vim ~/.bash_profile命令编辑bash_profile文件。
  • 6.bash_profile文件中添加export CSSHELL=~/CustomShellexport PATH=$CSSHELL:$CY:$THEOS:$PATH两行命令,保存并退出。
  • 7. 打开iTerm2终端,使用cd ~/Document命令定位到文档目录,使用sh login.shbash login.sh,source login.sh,. login.sh)进行测试脚本环境是否配置成功。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容