6.指针&Mach-O文件

[TOC]

指针的基础

指针宽度:在64位系统中占8个字节=64bit;

编译器决定了指针不能做乘法和除法,但能进行加减运算;

指针的运算

  • 求和 - 自增

    自增的结果取决于指针指向的数据类型的宽度(可以简易看成指针去掉一个后*看左边的数据类型)。如:

    int *a = (int *)100;
    a++; // 结果为a = (int *)104;
    char *a = (char *)100;
    a++; // 结果为a = (char *)101;
    
  • 普通求和

    指针加上一个整数的结果,其实就是指针指向的数据类型宽度决定的!

  • 求差

    指针求差,得到的结果是整形,其结果和指针指向的数据类型宽度有关!两个指针相减后需要除以数据宽度;如:

    int *a = (int *)100;
    int *b = (int *)200;
    int *x = a - b;
    // 得到的结果为(100 - 200) / 4 = -25;
    
    x = b - 199; // 得到的结果为-569,此时指针取出数据出错,可能是溢出,可能是跨数据片段取出错误数据。
    

    这也就是指针的特点! 它的运算单位 是数据类型的宽度!

指针反汇编

如指针源码:

int *a;
int b = 10;
a = &b;

对应汇编代码:

栈拉伸
x8, sp, #0x4  
w9, #0xa
w9, [sp, #0x4]
x8, [sp, #0x8]

数组补充:

int arr[] = {1, 2, 3, 4, 5};
for (int i = 0; i < 5; i++) {
    printf("%d\n", *(arr + i)); // 偏移后用*去地址对应的值
    // int *a == arr[0] == arr
}

int *a = arr;
a++; // a可以进行自加,但arr是不能的,这是编译器决定的

指针用法

主要是多级指针。

c源代码:

char **p1;    // p1 指向的是char *类型的数据类型,即去掉一个*后的类型
char c = **p1;  

对应汇编:

ldr x8, [sp, #0x8]
ldr x8, [x8]
ldr x9, [x8]

偏移计算:

char **p1;
char c = *(*(p1 + 2) + 2); //分别偏移0x10、0x2
char c1 = p1[1][2]; // //分别偏移0x8、0x2

逆向原理

动态调试 通过cycript、lldb等定位某类的某方法

静态分析 利用汇编,分析三方APP的源码

代码注入 注入的是动态库,hook代码 改变程序的执行流程

重签名 安装在非越狱手机上

Class-dump

usr/bin、usr/local/bin的区别;

class-dump的环境变量配置,即其在环境变量中出现多次时调用的顺序;

导出头文件:

$ class-dump -H MachO文件Path -o 头文件路径

Mach-O

官方介绍总共有11种格式! 是 Mach Object的缩写,是Mac\iOS 上用于存储程序,库的标准格式!
常见的格式:

  • 1.可执行文件
  • 2.objcet
    • .o 文件(目标文件),中间产物,clang编译结果
    • .a 静态库文件。其实就是N个.o文件的集合
  • 3.DYLIB: 动态库文件
    • dylib,对macOS
    • framework,对iOS
  • 4.动态连接器
  • 5.DSYM ,用于分析崩溃信息

clang指令

  1. 编译源文件:clang -c test.c得到.o文件,目标文件;使用file test.o查看文件类型;
  2. 链接:clang test.o,得到a.out,可执行文件;使用./a.out执行;
  3. 链接并命名-1:clang -o test test.o
  4. 编译、链接并命名-2:clang -o test1 test.c,一次性编译和链接、命名;
  5. 多个源文件编译并连接:clang -o demo test2.c test1.c,源文件的顺序不关心;

动态库共享缓存

为了提高性能,系统的动态库文件都存在了动态库共享缓存里面!

macOS:/private/var/db/dyld/dyld_shared_cache_x86_64h

动态加载器(dyld)

用于调用加载缓存库,macOS:/usr/lib/dyld

  • dynamic linker
    dynamic loade

Xcode中的架构设置

Build Active Architecture Only:只编译当前架构版本。在release、debug设置不一样;

Architecture:架构;Valid Architecture:有效架构;

在编译时生成mach-o支持的平台是ArchitectureValid Architecture的交集;

拆分二进制文件

经常用于整合静态库。

静态分析时多数时候是针对某一个架构,所以可以先拆分开不同的架构;

通用可执行文件的大小不是和的大小,因为不同架构中间有相同的部分;

瘦身

$ lipo 002--可执行文件 -thin armv7 -output macho_armv7
$ lipo 002--可执行文件 -thin arm64 -output macho_arm64

整合

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,858评论 25 707
  • 如果你不是三月的清风 为何要偷偷蹿进我四月的城 撞倒醉人的花香,惹一场莺燕歌舞 如果你不是六月洁白的木槿 为何要朝...
    LS醉生梦死阅读 128评论 1 0
  • 学习了教师职业道德,老师们感慨万千,在交流学习心得的时候,一个个侃侃而谈,职业道德在老师的脑海里留下了深刻的印象,...
    朦胧雨烟阅读 171评论 0 1
  • 从去年冬天到如今的春暖花开,整整四个月,邺终成没有像今天这么开心了。因为今天,他从半屏岛的一个老渔民手中收到的...
    楠溪陈酿阅读 445评论 0 3
  • phantomjs:我的理解就是它是一个无显示的浏览器,也就是说除了不能显示页面内容以外,浏览器能干的活儿它基本上...
    北方蜘蛛阅读 5,810评论 1 2