是否可以使用python连接到Mobile Safari远程调试器协议?

时间:2011-12-22 04:23:18

标签: uiwebview webkit mobile-safari remote-debugging

我在iOS上运行了一个基于HTML5的应用程序,我希望使用iOS 5 1中现在支持的webkit远程调试器协议2来连接它。

我正在尝试追踪我的javascript应用程序难以崩溃浏览器(SEG_FAULT)的问题。我希望在执行时获得应用程序的跟踪,以便我可以看到可能导致问题的线路或网络操作。我目前的想法是编写一个python应用程序,它将连接到远程调试器,并在我与应用程序交互时继续逐步执行代码并将信息收集到日志文件中。

虽然我找不到任何关于如何连接到调试器并进行通信的示例或文档,或者即使有可能,但我遇到了初步障碍。

有没有人知道这是否可行,如果有,你能指出我的一些文档和/或示例代码吗?


基于下面的代码,我在github上创建了一个项目来测试一些想法。您可以在此处找到它:abierbaum:/python_webkit-remote_debugger

1 个答案:

答案 0 :(得分:6)

是的,如果您按照说明在UIWebView中启用了检查器,则应该可以从Python连接到它。我玩弄它,并想出如何使用Web Socket发送和接收命令。这是使用websocket-client

的Python 2.7脚本
import json
import socket

from websocket import WebSocket


ws = WebSocket()

# if ipv6
ws.io_sock = ws.sock = socket.socket(socket.AF_INET6, socket.SOCK_STREAM)
ws.connect("ws://localhost:9999/devtools/page/1")

counter = 0

def send(method, params):
  global counter
  counter += 1
  # separators is important, you'll get "Message should be in JSON format." otherwise
  message = json.dumps({"id": counter, "method": method, "params": params}, separators=(',', ':'))
  print "> %s" % (message,)
  ws.send(message)

def recv():
  result = ws.recv()
  print "< %s" % (result,)

send('Runtime.evaluate', {'expression': 'alert("hello from python")'})
recv()

这使用Runtime.evaluate功能显示警告。

我尝试在模拟器中运行的MobileSafari上运行它,它运行正常。我注意到两件重要的事情:

  • 远程服务器绑定到IPv6端口,如果没有该行来覆盖套接字并设置系列,则websocket-client不会连接。不确定它是在设备上还是在UIWebView中运行相同。
  • 它不喜欢JSON中分隔符周围的空格。

以下是使用gdb在MobileSafari中启用检查器并运行脚本的示意:

$ ps x | grep MobileSafari
 4968   ??  Z      0:00.00 (MobileSafari)
 6234   ??  S      0:00.69 /Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator5.0.sdk//Applications/MobileSafari.app/MobileSafari
 6238 s007  R+     0:00.00 grep MobileSafari
$ gdb
GNU gdb 6.3.50-20050815 (Apple version gdb-1708) (Thu Nov  3 21:59:02 UTC 2011)
...
(gdb) attach 6234
Attaching to process 6234.
Reading symbols for shared libraries . done
Reading symbols for shared libraries ........................................................................................................................................................ done
0x99798c22 in mach_msg_trap ()
(gdb) p (void *)[WebView _enableRemoteInspector]
$1 = (void *) 0x2ac93ce
(gdb) detach
Detaching from process 6234.
(gdb) quit
$ python debug.py 
> {"params":{"expression":"alert(\"hello from python\")"},"id":1,"method":"Runtime.evaluate"}
< {"result":{"result":{"type":"undefined","description":"undefined"}},"id":1}