文档章节

ios插件开发-theos环境搭建

余成海
 余成海
发布于 2016/02/22 14:25
字数 642
阅读 4394
收藏 0

theos 是ios在越狱环境下,开发的工程管理工具 https://github.com/DHowett/theos

下面分享下环境搭建过程:

  1. 给xcode安装 command line tools

    从10.8开始xcode的command line tools就要自己安装了,如果没安装的话,会出现各种问题,比如gcc没有安装,等等各种诡异的问题。新手很是害怕。

    https://developer.apple.com/downloads/?=Command%20Line%20Tools%20 

  2. 安装 macports 

    macports是用于安装dpkg的快速安装工具,还可以安装其他很多工具

    http://distfiles.macports.org/MacPorts 

  3. 设置配置

export THEOS=/opt/theos

   4.下载theos

sudo git clone https://github.com/moloch--/theos.git $THEOS

   5.安装dpkg

sudo port install dpkg

6. 下载 https://github.com/kokoabim/iOSOpenDev

7.下载的iOSOpenDev/lib  拷贝到 /opt/theos/lib 

8.下载的iOSOpenDev/include 拷贝到 /opt/theos/include

9.下载的iOSOpenDev/bin 拷贝到 /opt/theos/bin

 

环境基本完成,如果需要hook一些特殊的头文件,自己可以使用class_dump_z解析出来放到header里面,也可以在google中找

---------------------------------------------------凌乱的分割线------------------------------------------

1.创建工程

$THEOS/bin/nic.pl

NIC 1.0 - New Instance Creator —————————— 
[1.] iphone/application   
[2.] iphone/library   
[3.] iphone/preference_bundle   
[4.] iphone/tool   
[5.] iphone/tweak 
Choose a Template (required): 5
选择com.apple.springboard开发桌面插件

2.创建成功后,在工程目录下,修改MakeFile 修改头部第一行

export ARCHS = armv7
export TARGET=iphone:latest:5.1
include $(THEOS)/makefiles/common.mk

3.编写TWeak.xm文件代码

%hook SBScreenShotter 

- (void)saveScreenshot:(BOOL)screenshot { 
	%orig; 
 	UIAlertView *alert = [[UIAlertView alloc] initWithTitle:@"Welcome" message:@"Welcome to your iPhone love" delegate:nil cancelButtonTitle:@"okokok" otherButtonTitles:nil];
	[alert show]; 
	[alert release];
 } 

 %end
%hook后面跟的是你要hook的类名称,以一个%end结尾。上面的代码说明我们会hook Springboard类里面的method。
%orig
当在一个method内部的时候,%orig会调用原来的方法(original method)。你甚至可以给原来的method传递参数,例如:%orig(arg1,arg2)。如果你不调用%orig,原来的方法就绝对不会被调用。所以,如果你hook了SpringBoard的init方法,但是没有调用%orig。那么你的iphone就将不可用,除非你通过ssh删除你的app。

  上面代码的作用就是在桌面截屏的时候弹出一个对话框!,当然,如果你不知道的想要hook的函数是什么的话,请使用各种分析工具获得!,可以看上面几篇文章

4.增加frameWork

那是因为我们依靠UIKit framework来显示alert,所以需要在Makefile中加上如下一行:
WelcomeWagon_FRAMEWORKS = UIKit

5.打包

   cd到工程目录下,make,make成功后,使用

   设置配置安装

export THEOS_DEVICE_IP=10.242.125.7 (这是手机的IP)
make package install

 

 

© 著作权归作者所有

共有 人打赏支持
余成海
粉丝 62
博文 57
码字总数 29577
作品 0
杭州
iOS工程师
私信 提问
iOS逆向工程- 学习整理(工具详解)

前言 一、逆向工程的要求 具备丰富的 iOS 开发经验 最好能非常熟悉 iOS 设备的硬件构成,iOS 系统的运行原理。 拿到任意一个 App 之后能够大致推断出它的项目规模和使用的技术,比如它的MVC模...

_小迷糊
2018/05/11
0
0
THEOS/bin/nic.pl: No such file or directory

iOS逆向的时候,创建 Theos 工程时按照网上教程遇到 THEOS/bin/nic.pl: No such file or directory问题。 解决方法: theos 安装在哪里,找到nic.pl文件,直接拖入 terminal ,按回车就可以了...

xyzcwb
2018/09/12
0
0
大家进来看下我的简历吧,看看有什么需要改进的地方,谢谢啦

之前在51job和智联上投了好多简历,居然没有一个电话打来,心碎了,请各位帮忙看看我这简历有没有问题。谢谢拉 男 | 未婚 | 1991 年8月生 | 户口:安徽芜湖 | 现居住于安徽合肥 1年工作经验 ...

ZWZ2589
2013/06/08
1K
14
Cydia的基石:MobileSubstrate

在MAC与IOS平台上,动态库的后缀一般是dylid,而加载这些动态库的程序叫做dynamic linker(dyld)。这个程序有很多的环境变量来设置程序的一些行为,最为常用的一个环境变量叫做"DYLDINSERTLI...

HeroHY
2018/11/17
0
0
OGEngine v2.1.1 Mac开发环境搭建

OGEngine v2.1.1 Mac开发环境搭建 OGEngine v2.1.1拓展了iOS平台的支持,我们现在来搭建下开发环境。注意,由于iOS版本的编译开发必须在Mac系统上,所以我们的部署也是在Mac环境下进行的。 ...

橙游OrangeGame
2014/09/04
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Windows 上安装 Scala

在安装 Scala 之前需要先安装 Java 环境,具体安装的详细方法就不在这里描述了。 您可以自行搜索我们网站中的内容获得其他网站的帮助来获得如何安装 Java 环境的方法。 接下来,我们可以从 ...

honeymose
今天
1
0
数据库篇多表操作

第1章 多表操作 实际开发中,一个项目通常需要很多张表才能完成。例如:一个商城项目就需要分类表(category)、商品表(products)、订单表(orders)等多张表。且这些表的数据之间存在一定的关系...

stars永恒
今天
3
0
nginx日志自动切割

1.日志配置(Nginx 日志) access.log----记录哪些用户,哪些页面以及用户浏览器,IP等访问信息;error.log------记录服务器错误的日志 #配置日志存储路径:location / {      a...

em_aaron
昨天
5
0
java 反射

基本概念 RTTI,即Run-Time Type Identification,运行时类型识别。RTTI能在运行时就能够自动识别每个编译时已知的类型。   要想理解反射的原理,首先要了解什么是类型信息。Java让我们在运...

细节探索者
昨天
2
0
推荐转载连接

https://www.cnblogs.com/ysocean/p/7409779.html#_label0

小橙子的曼曼
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部