class-dump 使用

来源:互联网 发布:淘宝旺旺分流设置 编辑:程序博客网 时间:2024/06/07 03:05

class-dump 官网地址:这里

我这里下载的是 class-dump-3.5.dmg 版本的。双击.dmg 文件,将  拉倒 /usr / local / bin 目录下,这样就可以在终端使用 class-dump 命令了。

这里我演示dump系统自带的计算器,导出它的头文件。

命令如下:

class-dump -H /Applications/Calculator.app -o /Users/Rio/Desktop/calculate\ heads

解释:

/Applications/Calculator.app 是计算器app的路径

/Users/Rio/Desktop/calculate\ heads 是存放dump出来头文件的文件夹路径

[objc] view plaincopyprint?在CODE上查看代码片派生到我的代码片
  1. class-dump 3.5 (64 bit)  
  2. Usage: class-dump [options] <mach-o-file>  
  3.   
  4.   where options are:  
  5.         -a             show instance variable offsets  
  6.         -A             show implementation addresses  
  7.         --arch <arch>  choose a specific architecture from a universal binary (ppc, ppc64, i386, x86_64)  
  8.         -C <regex>     only display classes matching regular expression  
  9.         -f <str>       find string in method name  
  10.         -H             generate header files in current directory, or directory specified with -o  
  11.         -I             sort classes, categories, and protocols by inheritance (overrides -s)  
  12.         -o <dir>       output directory used for -H  
  13.         -r             recursively expand frameworks and fixed VM shared libraries  
  14.         -s             sort classes and categories by name  
  15.         -S             sort methods by name  
  16.         -t             suppress header in output, for testing  
  17.         --list-arches  list the arches in the file, then exit  
  18.         --sdk-ios      specify iOS SDK version (will look in /Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS<version>.sdk  
  19.         --sdk-mac      specify Mac OS X version (will look in /Developer/SDKs/MacOSX<version>.sdk  
  20.         --sdk-root     specify the full SDK root path (or use --sdk-ios/--sdk-mac for a shortcut)  

运行命令,可以看到已经dump出头文件了,如下所示:


   class-dump 虽然非常有用,但有时我们会发现 class-dump 执行失败,无法得到我们想要的 .h 文件,或者 .h 文件的内容是加密的密文。出现这种现象的原因是:class-dump 额作用对象必须是未经加密的可执行文件,而App Store 下载的 App 都是经过签名加密的,可执行文件被加上了一层“壳”。可以使用 AppCrackr 来自动砸壳。


PS:http://bbs.iosre.com/t/dumpdecrypted-app/22

最后一步:class-dump --arch armv7 -H ~/Desktop/JD4iPhone.decrypted -o ~/Desktop/JD

0 0
原创粉丝点击