我使用PHPStorm,xdebug和Nginx PHP-fpm进行远程调试.当我在请求GET参数中传递XDEBUG_SESSION_START = my_ide_key时,Nginx会使用502错误代码(Bad Gateway)进行调用.同时我在IDE中的代码断点工作正常.当我没有传递XDEBUG_SESSION_START参数时,Nginx响应格式良好的HTML和代码200.但是没有这个参数显然没有调试.
在Nginx错误日志中,我看到有关从上游收到的大标头的通知.我尝试在PHP-fpm和Nginx之间转储通信,只有一个不同的东西是一个Set-Cookie头:
@H_502_7@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标头数量).我确信我的代码中没有一个显式头(‘Set-Cookie:XDEBUG_SESSION = …’)调用.我尝试升级和降级xdebug版本但仍然具有相同的行为.在Smarty_Internal_Template放置代码remove_header(‘Set-Cookie’)解决了我的问题,但这是丑陋的黑客!
有关这种奇怪情况的任何想法?
在我使用PHPStorm的所有经验中,我发现打开xdebug的最佳方法是通过bookmarklet,您可以在此处生成:
https://www.jetbrains.com/phpstorm/marklets/
bookmarklet在浏览器中设置cookie.因此,在服务器中不执行任何代码来设置XDEBUG_SESSION和路径变量,这可以减少或消除对智能代码的干扰.
此外,PHPStorm的一个提示是确保PHPStorm启动并运行,并且PHPStorm和PHP-fpm之间的网络连接正常工作(我认为这是你与Nginx结合使用的).