逆向工程学习资料

转自:http://samdmarshall.com/re.html

Reverse Engineering Resources

Debugging

These are very important guides for understanding the debugging process and how applications work.

  • Mac OS X Debugging Magic Technical Note (TN2124) (link - PDF Mirror)
  • iOS Debugging Magic Technical Note (TN2239) (link - PDF Mirror)
  • Understanding and Analyzing iOS Application Crash Reports (TN2151) (link - PDF Mirror)
  • Malloc Debug Environment Variables (link - PDF Mirror)

Mach-O Binaries

Mac OS X and iOS use Mach-O file format for executable binaries and shared libraries. It supports multiple architectures in one binary file (Universal or fat binaries).

Analysis

Guides and introductory material to binary analysis.

  • Analyzing Binaries with Hopper (link)

System ABIs

Calling conventions define how functions and subroutines receive the parameters passed to them from the calling function.

Language Resources

Language specific knowledge is often required to understand what is going on behind the scenes.

Further Reading

Collection of blogs and reading resources that give deep insight into how many aspects of languages and system functionality.

  • NSBlog (link)
  • Reverse Engineering Mac OS X (link)
  • Landon's Blog (link)
  • OS X Internals (link)
  • Greg Parker's Blog (link)
  • Ridiculous Fish (link)
  • Snare's Blog (link)
  • To The Apple's Core (link)
  • The Objective-C Runtime: Understanding and Abusing (link)

Tools

Mach-O Binary Analyzers:

Hex Editors:

Disassemblers:

Decompilers:

Debuggers:

Memory Editors:

Various Command Line Tools:

Useful Source Repositories:

  • Apple Source Code (link)
  • PLCrashReporter (link)
  • Mike Ash's Github (link)
  • Landon Fuller's Github (link)
  • Jonathan Rentzsch's Github (link)
  • fG!'s Github (link)
  • openjailbreak (link)
posted on 2014-05-07 22:26  课蜜黄蜂  阅读(421)  评论(0编辑  收藏  举报