VS Code 不管理 PHP 会话,仅作为编辑器;会话由 PHP 运行时控制,需正确配置 php.ini(如 session.save_path、gc_maxlifetime)、显式指定配置文件启动内置服务器、配合 Xdebug 调试观察 $_SESSION,并区分 CLI 与 Web 环境的 php.ini。

VS Code 本身不管理 PHP 会话($_SESSION),它只是编辑器;会话由 PHP 运行时在 Web 服务器(如 Apache/Nginx)或 CLI 环境中控制。你真正需要配置的是:让 VS Code 正确启动 PHP 服务、识别 session 配置、并在调试时能观察会话变量。
php.ini 才算真正“管理 PHP 会话”PHP 的会话行为(比如 session 文件存放位置、过期时间、是否启用 cookie)全由 php.ini 中的配置项决定,VS Code 只是读取并可能帮你触发这些设置。常见关键项包括:
session.save_path:必须可写,否则 session_start() 失败且无提示session.cookie_lifetime 和 session.gc_maxlifetime:决定会话存活时长session.use_cookies 和 session.use_strict_mode:影响安全性与兼容性如果你在 VS Code 中运行 php -S 启动内置服务器,它默认**不加载系统 php.ini**,而是用精简配置——这意味着 session 可能根本不起作用,连 session_start() 都静默失败。
php -c "C:\php\php.ini" -S localhost:8000
这样显式指定配置文件,才能确保 session 相关设置生效。
$_SESSION 变量装好 PHP Debug 插件并配好 Xdebug 后,VS Code 调试器能直接显示 $_SESSION 内容,但前提是:
session_start())launch.json 中误设 "stopOnEntry": true 导致还没走到 session_start() 就停了调试时,在 $_SESSION 行打个断点,F5 启动后刷新页面,变量面板里就能看到实时值。如果显示 undefined 或空数组,大概率是:
session_start() 没执行(比如放在输出之后,触发了 “Headers already sent” 错误)session.save_path 不可写(Windows 上常见于 C:\Windows\Temp 权限不足)php script.php),而 CLI 默认不启用 session 扩展(需手动加 extension=session 到 CLI 的 php.ini)PHP Server 扩展快速起一个带 session 的本地环境这个扩展(by Brackets team)比手敲 php -S 更省心,但它默认也不读全局 php.ini。解决方法很简单:
php.executablePath,但仍不会加载 php.ini
"php.serve.path": "C:\\php\\php.exe -c C:\\php\\php.ini"
注意路径要用双反斜杠或正斜杠,且 -c 参数必须紧接在可执行文件后,中间不能有空格。
php.ini 是两套Windows 下,XAMPP/WAMP/独立 PHP 安装通常提供两个 php.ini 文件:
php.ini-development(用于 Web 服务器,Apache 加载它)php.ini-production(有时被 CLI 使用,或根本没被 CLI 加载)运行 php --ini 查看 CLI 实际加载哪个;运行 phpinfo() 页面查看 Web 端加载哪个。两者 session 配置不同,就会出现「浏览器里正常登录,命令行测试却报 session 不存在」这类问题。
别指望 VS Code 自动同步它们——你得自己核对、复制、或统一指向同一个 php.ini。