如何在XP + Apache 2.2 + XDebug上调试通过cURL发送到Wordpress的Atompub POST

时间:2008-12-15 16:53:11

标签: php netbeans curl xdebug

我一直在使用NetBeans作为XDebug交互式调试客户端。但似乎它只支持将调试器附加到通过Firefox调用的脚本。我想通过cURL调用请求解析脚本。

2 个答案:

答案 0 :(得分:2)

我想出了答案。首先,我通过右键单击netbeans中的wordpress项目并选择“debug”来附加调试器。这将在firefox中打开博客,其中包含url中包含的“XDEBUG_SESSION_START = netbeans-xdebug”参数(例如“http://localhost/wordpress/?XDEBUG_SESSION_START=netbeans-xdebug”)。

然后我从命令行调用cURL,确保设置一个名为/值为XDEBUG_SESSION / netbeans-xdebug的cookie:

>curl "http://localhost/wordpress/wp-app.php/posts" -X POST -H "Content-type: application/atom+xml" -v -L -k -u admin:password --data @post_atom_entry_bad.xml -o post_bad_response.txt -b XDEBUG_SESSION=netbeans-xdebug
* About to connect() to localhost port 80 (#0)
*   Trying 127.0.0.1... connected
* Connected to localhost (127.0.0.1) port 80 (#0)
* Server auth using Basic with user 'admin'
> POST /wordpress/wp-app.php/posts HTTP/1.1
> Authorization: Basic YWRtaW46d2Fuc3Vp
> User-Agent: curl/7.19.1 (i586-pc-mingw32msvc) libcurl/7.19.1 OpenSSL/0.9.8i zlib/1.2.3
> Host: localhost
> Accept: */*
> Cookie: XDEBUG_SESSION=netbeans-xdebug
> Content-type: application/atom+xml
> Content-Length: 302
>
} [data not shown]
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   302    0     0    0   302      0     74 --:--:--  0:00:04 --:--:--     0

此时cURL在我在wp-app.php,AtomParser-> handle_request()中的第283行设置的断点处停止,我可以单步调试代码。

点击F5(继续)后,服务器将响应发送回cURL:

  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100   302    0     0    0   302      0      2 --:--:--  0:02:17 --:--:--     0< HTTP/1.1 400 Bad Request
< Date: Mon, 15 Dec 2008 17:47:06 GMT
< Server: Apache/2.2.9 (Win32) DAV/2 mod_ssl/2.2.9 OpenSSL/0.9.8i mod_autoindex_color PHP/5.2.6
< X-Powered-By: PHP/5.2.6
< Content-Length: 0
< Connection: close
< Content-Type: text/plain
<
100   302    0     0    0   302      0      2 --:--:--  0:02:18 --:--:--     0* Closing connection #0


>

完成。很高兴从其他交互式调试客户端获取示例,例如notepad ++。

答案 1 :(得分:1)