我使用 PhpStorm、xdebug 和 nginx + php-fpm 进行远程调试。XDEBUG_SESSION_START=my_ide_key
当我传入请求GET
参数时,Nginx 以 502 错误代码(错误网关)响应。同时,我在 IDE 中的代码断点工作正常。当我不传递XDEBUG_SESSION_START
参数时,nginx 会以格式良好的 HTML 和代码 200 响应。但很明显,没有这个参数就没有调试。
在 nginx 错误日志中,我看到有关从上游收到的大标头的通知。我尝试转储 php-fpm 和 nginx 之间的通信,只有一个不同的东西是一个Set-Cookie
标头:
Set-Cookie: XDEBUG_SESSION=666; expires=Mon, 16-Sep-2013 16:07:28 GMT; path=/
我尝试查找此标头何时出现在响应中。而且我发现在我的 smarty 插件Smarty_Internal_Template
析构函数中(在我的启动脚本的最后一个代码行之后),如果我调用headers_list()
我会看到越来越多的 Set-Cookie 标头(相等的析构函数调用和 Set-Cookie 标头数量)。我确信header('Set-Cookie: XDEBUG_SESSION=...')
我的代码中没有一个明确的调用。我尝试升级和降级 xdebug 版本,但仍然有相同的行为。放置代码解决remove_header('Set-Cookie')
了Smarty_Internal_Template
我的问题,但那是丑陋的黑客!
对这种奇怪的情况有什么想法吗?