【问题标题】:Adding __Secure to PHPSESSID将 __Secure 添加到 PHPSESSID
【发布时间】:2018-12-14 04:42:29
【问题描述】:

我在 php.ini 中把它改成了

session.name = '__Secure-PHPSESSID'

但是,当我使用 session_start();唯一的 cookie 名为 PHPSESSID。 当我尝试使用

session_name('__Secure-PHPSESSID');
session_start();

根本没有 cookie 出现。我做错了什么?

【问题讨论】:

    标签: php session-cookies


    【解决方案1】:

    From the docs:

    会话名称引用会话的名称,该名称用于 cookie 和 URL(例如 PHPSESSID)。 它应该只包含字母数字字符;它应该简短且具有描述性(即对于启用了 cookie 警告的用户)。如果指定了名称,则当前会话的名称将更改为其值。

    尝试使用不带_- 的名称,例如SecurePHPSESSID

    session_name('SecurePHPSESSID');
    session_start();
    

    【讨论】:

    • 在 php.ini 中更改了它,但如果我不使用 session_name('SecurePHPSESSID'); session_start(); 调用它,它仍然显示为 PHPSESSID...此外,我的 php.ini 中的其他标志都没有被传递
    • @sharkondero 可能是因为您编辑了错误的php.ini,因为有多个。 (命令行、服务器等)。创建一个包含 <?php phpinfo(); 的文件并查找 used php.ini 的路径
    • 虽然,当我通过 ini_set('session.cookie_httponly', 1); ini_set('session.cookie_secure', 1); session_start(); 时,一切正常
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2021-11-03
    • 2011-03-12
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-06-24
    • 2010-11-25
    相关资源
    最近更新 更多