无法让 php 的 $_SESSION 在我的本地计算机上工作
它在实时服务器上工作正常,但在本地计算机上无法工作
我尝试过在 Windows 上使用 apache 和 php,在 Mac 上使用 apache 和 php,在 debian 上使用 apache 和 php,但它们都不起作用(我的实时服务器也在运行 debian 9,与我在本地尝试过的服务器相同)
在firefox的开发者工具>网络>标头中,我可以看到php正在发送set-cookie,但由于某种原因它没有被设置(存储中没有cookie>cookie,并且我的脚本在设置cookie时无法正常工作)
我没有使用 ssl/https 并且我设置了“session.cookie_secure = 0 并关闭”,但由于某种原因,这就是 set-cookie 标头的样子:“Set-Cookie: PHPSESSID=XXXXX;path=/;HttpOnly ;安全”,我不认为 php 应该设置安全标志,因为我在 php.ini 中明确禁用了它?
是的,每个使用会话功能的文件中都有一个 session_start()
没有任何 apache/php 错误,我什至启用了 xdebug
使用 localhost、127.0.0.1、10.0.0.10(我的 lan ip )和自定义主机名进行测试,没有任何效果
我没有主意,尝试了我能想到的一切
在使用 php 7.2 和默认配置的实时 debian 9 服务器上运行
不适用于具有 php 7.2 和默认配置的本地 debian 9 服务器
不适用于具有相同 apache/php 版本的 Windows
不适用于装有 apache 2.4 和 php 7.3 的 Mac,甚至不适用于
session.cookie_secure=0 设置
检查了 apache 和 php 错误,没有
使用 Firefox 的开发者工具查看 headers/cookie
检查我的代码并确保它有 session_start() 并且其他所有内容都是正确的
我什至尝试手动设置 cookie,并将安全标志设置为 false,并再次在 Set-Cookie 标头中设置“安全”,这是代码:
setcookie("PHPSESSID", "7nhqdim7uu2viae7vhhf9os5ue", 0, "/", "", false, false);
这是我用于测试的代码:
<?php
session_start();
var_dump($_SESSION);
if(isset($_POST['submit']))
{
$_SESSION['value'] = $_POST['example'];
header('Location: /session.php'); // session.php is this file
}
if(isset($_SESSION['value']) && $_SESSION['value'] == 'example')
{
echo "value is " . $_SESSION['value'] . '<br>';
}
?>
<form method="post">
<input type="text" name="example" value="example">
<input type="submit" name="submit" value="submit">
</form>