ios下厨房作品自动点赞(越狱开发)

笔者是一枚程序员,同时也是个美食爱好者,一直想用技术做点自己的事情,刚好最近开始研究逆向工程,实现下厨房作品自动点赞的小功能,以后再也不用点赞点到手抽筋了,哈哈哈~

本文纯粹用于学习研究,希望各位读者不要用户商业或其它非法途径上,笔者概不负责哦~
本文是一篇关于越狱开发的文章,以下内容均以越狱机器为前提
笔者也是刚刚学习越狱开发,不喜勿喷,同时欢迎高手指导,谢谢大家~

本文的参考文章如下,感谢两位博主的分享:
一步一步实现iOS微信自动抢红包(非越狱)
iOS Security

接下来我们进入正题,首先,我们先来研究下Hook的流程:


越狱流程图.png
  1. 脱壳:
    从AppStore下载应用,并使用dumpdecrypted.dylib脱壳,脱壳之后生成.decrypted文件

  2. 导出头文件:
    使用class-dump导出头文件,导出后可将所有头文件放到一个XCode工程中方便阅读

  3. 分析:
    分析要Hook方法,根据自己想要Hook的功能,借助Reveal工具等定位到具体的method

  4. 创建tweak项目:
    本文中使用theos,修改tweak.xm文件,编写代码

  5. 打包,注入:
    利用thoes自动打包并注入到应用中

  6. 调试:
    使用syslog调试,修改之后重新打包

越狱开发的大概流程如上所述,以下厨房作品自动点赞功能为例,详细步骤如下:

脱壳

准备工作:
下载dumpdecrypted-master.zip,下载完成之后,解压,进入dumpdecrypted-master目录下,执行make命令即可生成dumpdecrypted.dylib

  1. 从AppStore中下载下厨房的ipa文件,保留备用,同时在越狱手机上安装一份
  • ssh到手机上,在terminal中执行如下命令:
ssh root@ip
  • 在手机上打开下厨房应用(最好将其它应用都关掉),在terminal中执行如下命令, 找到mach-o文件
ps -e

执行结果如下:

ps -e 执行结果

可看到mach-o文件路径为:
/var/mobile/Containers/Bundle/Application/E5380AA9-7785-449C-A94E-154E9AEAB147/recipe.app/recipe

  • 找到应用document位置,在terminal中执行如下命令开始cycript调试:
cycript -p recipe

然后在cycript下执行代码,获取document位置

NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)[0]

执行结果如下:

获取document路径

可以看到document路径为:
/var/mobile/Containers/Data/Application/02DFAEDA-14D1-4486-8890-F239C8D29FB1/Documents

  • 将dumpdecrypted.dylib放到该应用的Document下面
    使用scp将dumpdecrypted.dylib拷贝到Document目录下面,scp命令如下:
scp dumpdecrypted.dylib root@192.168.2.3:/var/mobile/Containers/Data/Application/02DFAEDA-14D1-4486-8890-F239C8D29FB1/Documents
  • 脱壳
    脱壳命令如下,DocumentPath为上面获取到的Document目录,machOpath为mach-o文件的位置:
DYLD_INSERT_LIBRARIES=/DocumentPath/dumpdecrypted.dylib /machOpath

本例中执行语句如下:

DYLD_INSERT_LIBRARIES=/var/mobile/Containers/Data/Application/02DFAEDA-14D1-4486-8890-F239C8D29FB1/Documents/dumpdecrypted.dylib /var/mobile/Containers/Bundle/Application/E5380AA9-7785-449C-A94E-154E9AEAB147/recipe.app/recipe

脱壳之后会在手机的当前目录下生成XX.decrypted文件,一般在根目录下:/var/root,再次使用scpXX.decrypted文件下载到本地。

class-dump导出头文件

脱壳之后的文件就可以使用class-dump将头文件导出了,导出命令如下:

./class-dump -s -S -H ./XX.decrypted -o ./filedir

filedir为导出文件夹,随意指定,导出后可以在文件夹下面看到recipe的.h文件,为了方便浏览可以新建一个工程并导入

找出要hook的方法

笔者也是越狱刚刚入门,并没有用IDA等高级的工具,这里使用的工具有RevealCharles

  1. 这里使用reveal来定位到下厨房每一餐作品页面的Controller

    在Reveal找到对应的Controller

  2. 定位到方法

    • 找到controller为XcfEventViewController之后,就可以在刚刚class-dump导出的文件XcfEventViewController .h中去找点赞的方法,但是看了一下发现并没有类似favor的方法,为了确定点赞方法的名称,我们使用Charles来查看下点赞的接口,如图:

      charles查看点赞接口信息

      我们发现URL里面有dishes和digg字段

    • 根据这两个单词我们去XcfEventViewController .h里面查找,发现并没有相关方法,那么,根据以往经验,一般这种方法我们会写在Cell里面,那同样适用Reveal定位到cell的名称为XcfNewDishGridView

    • 果然,在XcfNewDishGridView .h里面找到一个名称为diggDish的方法,接下来在代码中验证我们找到的方法是否正确

创建tweak工程

  1. 安装thoes,并创建tweak工程
    具体怎样安装不多说,详细可以查看http://security.ios-wiki.com/issue-3-6/

  2. 修改tweak.xm文件
    核心代码其实很简单,只是在collectionView:cellForItemAtIndexPath里面调用cell的diggDish方法:

    [cell diggDish];

但是,点赞还需要很多条件,首先我们要定位到哪个作品,然后根据作品判断是否符合点赞的条件,比如:
判断是否已经点赞过
是否会越界以防崩溃
检查id是否合法
这些都要一步步的去思考、调试

  1. 打包,terminal进入到tweak工程目录下,执行两条命令:
make
make package install

deb包会自动安装到越狱设备上
注意,安装theos之后THEOS_DEVICE_IP一定要配,这个是你自己越狱设备的IP,这样才可以通过上面的命令安装到你的设备上

调试

打包之后有可能会有问题,这就需要我们使用syslog来调试找到问题,syslog的使用方法如下:

grep recipe /var/log/syslog

可以在代码里使用NSLog,这样打印出的内容就可以在syslog文件中看到,可以把recipe替换成任何你想要查找的文字

当然,并不是所有的问题都可以在syslog中查到,一些业务问题不大会报错,可能比较难查找,要综合分析,笔者碰到的问题比如:
列表中有一些id=0的情况,这些数据应当排除掉,那么取到dish.id和dish.eventId发现都无法实现效果,和charles比对才发现id被开发者隐藏起来,通过shareObjectIdentifier方法提供

结束

除此之外还遇到其他一些小问题,这里就不一一给大家介绍了,在越狱开发的过程中会碰到很多问题,静下心来思考总会找到办法解决的,希望和大家一同进步_

本例详细的代码可以去我的github上面下载:
github地址
同时也希望感兴趣的小伙伴帮我点个赞哦~互相帮助,大家都懂的~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容