如何在Electra越狱的设备上使用LLDB调试应用程序
本篇文章给大家分享的是有关如何在Electra越狱的设备上使用LLDB调试应用程序,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。
我试图在google搜索,有关使用Electra越狱的iOS设备上调试AppStore应用程序的简要说明。但令我失望的是,竟然没有找到任何有用的资料。经过我的测试它非常的适用于我,但我无法确定它是否同样适用于你。我在以下设备进行了测试:
运行iOS 11.1.2的iPhone 7
运行iOS 11.0.1的iPhone 5s
这两款设备都使用Electra jailbreak 1.0.4进行了越狱。
从Xcode将debugserver部署到你的设备
首先,通过ssh连接到你的iOS设备,查看/Developer/usr/bin/debugserver是否存在。如果不存在则,
在Mac上运行Xcode
为iOS打开ObjC项目(或从头创建一个新项目)
保持Xcode运行状态。将你的iOS设备连接到USB
接着在Xcode中你应该看到,如下红框内所示的信息:
等到"准备调试支持iPhone"完成。然后在设备上检查 /Developer/usr/bin/debugserver。此时,debugserver二进制文件应该已经存在。
通过USB进行调试
对我而言,它只在我通过USB进行调试时才有效。如果Mac上未安装iproxy,请通过brew进行安装:
$ brew install usbmuxd
然后在Mac控制台中运行:
$ iproxy 6666 6666 &$ iproxy 2222 22 &
最后,将iPhone连接到USB。就是这样,我们准备开始。
将LLDB attach到已经运行的进程
在你的Mac控制台上,连接iPhone:
$ ssh -p 2222 root@localhost
在iPhone的控制台中运行
# ps ax
找到你想要attach的进程的pid。然后运行
# /electra/jailbreakd_client1# /Developer/usr/bin/debugserver localhost:6666 -a
如果你看到和我类似的内容
debugserver-@(#)PROGRAM:debugserver PROJECT:debugserver-360.0.26.14 for arm64.Attaching to process 1418...Listening to port 6666 for a connection from localhost...
则表明运行一切正常。现在,在Mac上打开另一个控制台,然后运行
$ lldb
在LLDB控制台中运行
(lldb) platform select remote-ios(lldb) process connect connect://localhost:6666
在LLDB下运行应用程序
在你的Mac控制台上,连接iPhone:
$ ssh -p 2222 root@localhost
在iPhone的控制台中运行
# /Developer/usr/bin/debugserver localhost:6666 -x backboard /var/containers/Bundle/Application/
如果你看到和我类似的内容
debugserver-@(#)PROGRAM:debugserver PROJECT:debugserver-360.0.26.14 for arm64.Listening to port 6666 for a connection from localhost...
则表明运行一切正常。现在,在Mac上打开另一个控制台,然后运行
$ lldb
在LLDB控制台中运行
(lldb) platform select remote-ios(lldb) process connect connect://localhost:6666
重要提示!如果你遇到了错误,请尝试:
在没有调试器的情况下运行应用程序
如前一节所述,将调试器attach到应用程序
关闭(LLDB)应用程序
在调试器下再次运行应用程序
以上就是如何在Electra越狱的设备上使用LLDB调试应用程序,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注行业资讯频道。