




已阅读5页,还剩16页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
初识Mach-O,M了个J,APP从开发到安装到手机的过程1,MJRefreshExample.app中的MJRefreshExample文件是iOS中的可执行文件,文件格式是Mach-O,编译、链接、签名,zip压缩,APP从开发到安装到手机的过程2,通过PP助手、iFunBox、Xcode等工具安装,上传,下载,逆向APP的思路,界面分析Cycript、Reveal代码分析对Mach-O文件的静态分析MachOView、class-dump、HopperDisassembler、ida等动态调试对运行中的APP进行代码调试debugserver、LLDB代码编写注入代码到APP中必要时还可能需要重新签名、打包ipa,class-dump,顾名思义,它的作用就是把Mach-O文件的class信息给dump出来(把类信息给导出来),生成对应的.h头文件官方地址:,常用格式class-dump-HMach-O文件路径-o头文件存放目录-H表示要生成头文件-o用于制定头文件的存放目录,代码的编译过程,Mach-O文件,可逆,在同一种架构平台下,每一条汇编指令都有与之对应的唯一的机器指令,编译,编译,反编译,汇编语言,OC语言,机器语言,代码的编译过程,不同的OC代码,编译出来的汇编代码可能是一样的,HopperDisassmbler,HopperDisassmbler能够将Mach-O文件的机器语言代码反编译成汇编代码、OC伪代码或者Swift伪代码常用快捷键Shift+Option+X找出哪里引用了这个方法,动态库共享缓存(dyldsharedcache),从iOS3.1开始,为了提高性能,绝大部分的系统动态库文件都打包存放到了一个缓存文件中(dyldsharedcache)缓存文件路径:/System/Library/Caches/com.apple.dyld/dyld_shared_cache_armXdyld_shared_cache_armX的X代表ARM处理器指令集架构v6iPhone、iPhone3GiPodTouch、iPodTouch2v7iPhone3GS、iPhone4、iPhone4SiPad、iPad2、iPad3(TheNewiPad)iPadminiiPodTouch3G、iPodTouch4、iPodTouch5v7siPhone5、iPhone5CiPad4,arm64iPhone5S、iPhone6、iPhone6Plus、iPhone6S、iPhone6SPlusiPhoneSE、iPhone7、iPhone7Plus、iPhone8、iPhone8Plus、iPhoneXiPad5、iPadAir、iPadAir2、iPadPro、iPadPro2iPadminiwithRetinadisplay、iPadmini3、iPadmini4iPodTouch6所有指令集原则上都是向下兼容的动态库共享缓存一个非常明显的好处是节省内存现在的ida、Hopper反编译工具都可以识别动态库共享缓存,APP1,APP2,APP3,UIKit,MapKit,APP1,APP2,APP3,共享缓存,UIKit,MapKit,动态库的加载,在MaciOS中,是使用了/usr/lib/dyld程序来加载动态库dylddynamiclinkeditor,动态链接编辑器dynamicloader,动态加载器dyld源码,从动态库共享缓存抽取动态库,可以使用dyld源码中的launch-cache/dsc_extractor.cpp将#if0前面的代码删除(包括#if0),把最后面的#endif也删掉,编译dsc_extractor.cppclang+-odsc_extractordsc_extractor.cpp使用dsc_extractor./dsc_extractor动态库共享缓存文件的路径用于存放抽取结果的文件夹,Mach-O,Mach-O是Machobject的缩写,是MaciOS上用于存储程序、库的标准格式属于Mach-O格式的文件类型有,可以在xnu源码中,查看到Mach-O格式的详细定义(,常见的Mach-O文件类型,MH_OBJECT目标文件(.o)静态库文件(.a),静态库其实就是N个.o合并在一起MH_EXECUTE:可执行文件.app/xxMH_DYLIB:动态库文件.dylib.framework/xxMH_DYLINKER:动态链接编辑器/usr/lib/dyldMH_DSYM:存储着二进制文件符号信息的文件.dSYM/Contents/Resources/DWARF/xx(常用于分析APP的崩溃信息),1.c,2.c,3.c,可执行文件,1.o,2.o,3.o,链接,编译,编译,编译,在Xcode中查看target的Mach-O类型,Mach-O的基本结构,官方描述,窥探Mach-O的结构,命令行工具file:查看Mach-O的文件类型file文件路径otool:查看Mach-O特定部分和段的内容lipo:常用于多架构Mach-O文件的处理查看架构信息:lipo-info文件路径导出某种特定架构:lipo文件路径-thin架构类型-output输出文件路径合并多种架构:lipo文件路径1文件路径2-output输出文件路径GUI工具MachOView(,UniversalBinary(通用二进制文件),通用二进制文件同时适用于多种架构的二进制文件包含了多种不同架构的独立的二进制文件因为需要储存多种架构的代码,通用二进制文件通常比单一平台二进制的程序要大由于两种架构有共同的一些资源,所以并不会达到单一版本的两倍之多由于执行过程中,只调用一部分代码,运行起来也不需要
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 80米彩虹滑道施工方案
- 房租租凭合同范本6
- 砖厂的用工合同范本
- 年度律师顾问合同范本
- 外墙石材干挂工程劳动合同4篇
- 茶叶种植收购合同范本
- 装修合作框架合同范本
- 代办报价合同范本
- 县政府信息公开保密审查制度
- 售后服务委托协议范本4篇
- 废铁拆除安全合同协议书
- 2025-2026学年人美版(2024)小学美术三年级上册(全册)教学设计(附目录P157)
- 点胶正式员工考试及答案
- 外研版(2024)八年级上册英语Unit 1 This is me 教案(共6课时)
- 2025年GCP考试试题库含答案
- 消保化解案例课件
- 2025浙江省知识产权研究与服务中心编外招聘12人考试备考试题及答案解析
- 2025年度东营市专业技术人员继续教育公需科目试卷及答案
- 用浪浪山正确打开开学第一课~课件
- 2025年幼儿园膳食工作计划
- 贵州省黔东南苗族侗族自治州2024-2025学年七年级下学期7月期末考试地理试卷含答案
评论
0/150
提交评论