iOS 逆向编程(二十二)Hopper Disassmbler 安装使用

简介: iOS 逆向编程(二十二)Hopper Disassmbler 安装使用

一、安装

安装好打开后,没有购买的就点试用

然后就进来了

二、使用

  • Mach-O 文件拖到 Hopper Disassmbler 软件里面,我现在拖的是 应用程序 文件,右键显示包内容里面就有 Mach-O,区别只是你找到或它找到 Mach-O

  • 每项配置的含义,翻译下就知道了,直接点 OK 就行了,然后就得到了 Mach-O 文件 汇编代码,如果包比较大,解析需要点时间,使用也会有点卡,可以提早进行解析。

  • 先看下我用来测试的 Mach-O 文件源码,方便做比较。

- (void)viewDidLoad {
    [super viewDidLoad];
    NSString * string = @"dzm";
    NSLog(@"%@", string);
}
  • 通过 Hopper Disassmbler 看到汇编代码之后,怎么看 OC 或者 Swift 伪代码呢?

/* @class ViewController */
-(void)viewDidLoad {
  var_20 = self;
  [[&var_20 super] viewDidLoad];
  var_28 = [@"dzm" retain];
  NSLog(@"%@", var_28);
  objc_storeStrong(&var_28, 0x0);
  return;
}

会发现 伪代码原代码 还是有很多相似地方的。


下面是扩展内容,可以不看。


三、如何查看官方框架源代码呢?比如:UIKit

  • 怎么找到 UIKitMach-O 文件,通过路径找到 UIKit.framework, 需要手动按文件层级照下来,路径是一样的。
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks/UIKit.framework
• 1
  • 找到 UIKit.framework 之后,会发现并没有 Mach-O 文件,只有一个 UIKit.tbd 文件,这个 UIKit.tbd 文件里面就有存放 UIKitMach-O 文件路径,它就是文本文件,直接打开就行。

  • 但是这个路径是手机上的存放路径,所以我们需要通过 命令行连接手机 或者 iFunBox 来访问这个路径并将 Mach-O 拷贝出来。
/System/Library/Frameworks/UIKit.framework/UIKit
  • 也可以通过命令行获得路径 UIKit 在手机上的路径,这个跟上面查看 UIKit.tbd 得到的文件路径一致,选其一即可。
// 连接手机
dengzemiaodeMacBook-Pro:~ dengzemiao$ sh /Users/dengzemiao/Desktop/ssh/login.sh 
// 搜索 app PID
iPhone:~ root# ps -A | grep neteasemusic
PID TTY           TIME CMD   
621 ??         0:28.44 /var/containers/Bundle/Application/C32DF80E-733A-4426-B915-FD05A426E319/neteasemusic.app/neteasemusic
// 监听 PID
iPhone:~ root# cycript -p 621 
// 导入 DZMCycript
cy# @import DZMCycript
{}
// 加载 UIKit
cy# DZMLoadFramework('UIKit')
// 查看导入路径,路径跟上面是一样的。
#"NSBundle </System/Library/Frameworks/UIKit.framework> (loaded)"
  • 通过 iFunBox 访问手机系统目录 /System/Library/Frameworks/UIKit.framework,找到 UIKitMach-O 文件。

  • 进来文件之后,并没有看到找到 UIKitMach-O 文件,那它在哪里呢? 这里有个概念叫 动态库共享缓存( dyld shared cache )

四、什么是 动态库共享缓存( dyld shared cache )?

  • iOS3.1 开始为了提高性能,绝大部分的系统动态库文件都打包存放到了一个缓存文件中 ( dyld shared cache ),缓存文件路径:
/System/Library/Caches/com.apple.dyld/dyld_shared_cache_armX
  • dyld_shared_cache_armXX 代表 ARM 处理器指令集架构,可能是 ..._armv6..._armv7..._arm7s..._arm64 等,所有指令集原则上 都是向下兼容 的,高等级支持所有低等级的。
  • 既然知道了 UIKitMach-O 在哪个文件,可以找到它看看,找到目录之后发现是有个 dyld_shared_cache_arm64 的文件,我们把它导出来到桌面。

  • 然后将它拖拽到 Hopper Disassmbler 里面,发现会是 DYLD Shared Cache (individual file),这个时候我们就需要通过下面的搜索找到 UIKit 了,并选中它,点击 Next

    搜索之后,由于有很多都是 UIKit 的,我们可以看路径,找到我们之前得到的路径 /System/Library/Frameworks/UIKit.framework,匹配上了就是它了。

    点击 Next 就识别到了 UIKitMach-O 了,点击 OK 就行了。

  • 下章会写到 dsc_extractor 动态库提取器,将 dyld_shared_cache_armX 动态文件内容全部提取出来使用。


相关文章
|
2月前
|
API Android开发 iOS开发
深入探索Android与iOS的多线程编程差异
在移动应用开发领域,多线程编程是提高应用性能和响应性的关键。本文将对比分析Android和iOS两大平台在多线程处理上的不同实现机制,探讨它们各自的优势与局限性,并通过实例展示如何在这两个平台上进行有效的多线程编程。通过深入了解这些差异,开发者可以更好地选择适合自己项目需求的技术和策略,从而优化应用的性能和用户体验。
|
4月前
|
Swift iOS开发 UED
揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【9月更文挑战第5天】本文通过具体案例介绍如何在iOS应用中使用Swift与UIKit实现自定义按钮动画,当用户点击按钮时,按钮将从圆形变为椭圆形并从蓝色渐变到绿色,释放后恢复原状。文中详细展示了代码实现过程及动画平滑过渡的技巧,帮助读者提升应用的视觉体验与特色。
76 11
|
5月前
|
Swift iOS开发 UED
【绝妙创意】颠覆你的视觉体验!揭秘一款iOS应用中令人惊叹的自定义动画效果,带你领略编程艺术的魅力所在!
【8月更文挑战第13天】本文通过一个具体案例,介绍如何使用Swift与UIKit在iOS应用中创建独特的按钮动画效果。当按钮被按下时,其形状从圆形变化为椭圆形,颜色则从蓝色渐变为绿色;释放后,动画反向恢复原状。利用UIView动画方法及弹簧动画效果,实现了平滑自然的过渡。通过调整参数,开发者可以进一步优化动画体验,增强应用的互动性和视觉吸引力。
65 7
|
5月前
|
安全 测试技术 调度
iOS开发-多线程编程
【8月更文挑战第12天】在iOS开发中,属性的内存管理至关重要,直接影响应用性能与稳定性。主要策略包括:`strong`(强引用),保持对象不被释放;`weak`(弱引用),不保持对象,有助于避免循环引用;`assign`(赋值),适用于基本数据类型及非指针对象类型;`copy`(复制),复制对象而非引用,确保不变性。内存管理基于引用计数,利用自动引用计数(ARC)自动管理对象生命周期。此外,需注意避免循环引用,特别是在block中。最佳实践包括理解各策略、避免不必要的强引用、及时释放不再使用的对象、注意block中的内存管理,并使用工具进行内存分析。正确管理内存能显著提升应用质量。
|
6月前
|
移动开发 开发工具 Android开发
探索安卓与iOS开发的差异:平台特性与编程实践
【7月更文挑战第8天】在移动开发的广阔天地中,安卓和iOS这两大操作系统各自占据着半壁江山。它们在用户界面设计、系统架构及开发工具上展现出截然不同的特色。本文将深入探讨这两个平台在技术实现和开发生态上的关键差异,并分享一些实用的开发技巧,旨在为跨平台开发者提供有价值的见解和建议。
|
6月前
|
IDE 开发工具 Android开发
安卓与iOS开发环境对比分析:选择适合自己的编程平台
移动应用开发的两大阵营——安卓和iOS,各自拥有不同的开发环境和工具集。本文通过深入比较这两个平台的编程语言、集成开发环境(IDE)、用户界面设计、测试框架以及部署流程,旨在为开发者提供一个全面的视角来选择最符合个人或项目需求的开发环境。
|
7月前
|
安全 IDE Android开发
探索Android与iOS开发的差异:平台特性与编程实践
【6月更文挑战第17天】在移动应用开发的广阔天地中,Android和iOS两大平台各自占据半壁江山。它们在用户群体、系统架构以及开发环境上的差异,为开发者带来了不同的挑战和机遇。本文深入探讨了这两个平台在技术实现、界面设计、性能优化等方面的主要区别,并提供了实用的开发建议,旨在帮助开发者更好地理解各自平台的特性,从而创造出更加优秀的移动应用。
|
数据安全/隐私保护 iOS开发 开发者
iOS 逆向编程(三)实操 Jailbreak 详细流程
iOS 逆向编程(三)实操 Jailbreak 详细流程
261 1
|
iOS开发
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(五)(3)
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(五)
170 0
|
前端开发 数据处理 iOS开发
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(五)(2)
实战编程·使用SwiftUI从0到1完成一款iOS笔记App(五)
99 0