反编译app

LLDB调试第三方APP(配置)

2017-04-07  本文已影响218人  YxYYxY

使用LLDB调试第三方APP

准备工作:越狱手机一台,有装openSSH

一、mac安装usbmuxd

具体教程请看我的另一篇文章SSH连接越狱iPhone(WIFI和USB)当中有提到安装usbmuxd

二、配置debugserver

此文件位于/Developer/usr/bin目录下,可以用pp助手等第三方工具复制到Mac上.

armv7s:iPhone5|iPhone5C|iPad4(iPad with Retina Display)
armv7:iPhone4|iPhone4S|iPad|iPad2|iPad3(The New iPad)|iPad mini|iPod Touch 3G|iPod Touch4
i386是针对intel通用微处理器32位处理器
x86_64是针对x86架构的64位处理器
模拟器32位处理器测试需要i386架构,
模拟器64位处理器测试需要x86_64架构,
真机32位处理器需要armv7,或者armv7s架构,
真机64位处理器需要arm64架构。

* #####给debugserver添加task_for_pid权限
将此段代码保存为xml文件,命名为ent.xml   

```Objective-C
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
  <dict>
      <key>com.apple.springboard.debugapplications</key>
      <true/>
      <key>get-task-allow</key>
      <true/>
      <key>task_for_pid-allow</key>
      <true/>
      <key>run-unsigned-code</key>
      <true/>
  </dict>
</plist>

放到与debugserver用一目录下(就是刚刚那个aaa文件夹)


cd到aaa文件夹执行ldid -Sent.xml debugserver

至此,处理debugserver已经完成了,因为文件夹里的文件都没变,大家可以看debugserver文件的大小来判断是否变化了,从iOS设备里拿出来的时候是10多m,现在已经只有4m多了(这个大小我不确定是不是每个人都一样)

三、将debugserver传回手机上

要注意一下不是传回/Developer/usr/bin目录,这个目录是只读的,传不进去,而是将文件传到/usr/bin目录下,我还是用pp助手来传回去(也可以使用SCP命令)

通过ssh连接到手机,连接教程,cd到/usr/bin目录下执行
chmod +x debugserver
通过debugserver来看是否成功

四、debugserver与LLDB的连接

五、使用lldb命令开始调试

我随意po一下po [[UIWindow keyWindow] recursiveDescription]

更多的lldb命令和技巧可以看以下文章
与调试器共舞 - LLDB 的华尔兹
深入了解GDB和LLDB
lldb与gdb命令名的对照表

文中有不对的地方还希望大家指正!

上一篇 下一篇

猜你喜欢

热点阅读