PHP 如何创建多个会话?

2022-08-30 21:53:21

我希望能够在php中的会话之间来回切换。这是我当前的代码:

<?php

session_name("session1");
session_start();
$_SESSION["name"] = "1";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

session_name("session2");
session_start();
$_SESSION["name"] = "2";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

session_name("session1");
session_start();
echo "<pre>", print_r($_SESSION, 1), "</pre>";

我希望它输出

Array
(
    [name] => 1
)
Array
(
    [name] => 2
)
Array
(
    [name] => 1
)

但它正在输出

Array
(
    [name] => 1
)
Array
(
    [name] => 2
)
Array
(
    [name] => 2
)

是否可以在这样的会话之间切换?我不需要同时运行两个会话,但我确实需要能够在它们之间切换。当我运行此代码时,我得到两个具有相同值的cookie:session1和sultsion2。

感谢您的任何帮助!


答案 1

您需要使用的是而不是session_id()session_name()

<?php

session_id("session1");
session_start();
echo session_id();
$_SESSION["name"] = "1";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

session_id("session2");
echo session_id();
session_start();
$_SESSION["name"] = "2";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

session_id("session1");
echo session_id();
session_start();
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

session_id("session2");
echo session_id();
session_start();
echo "<pre>", print_r($_SESSION, 1), "</pre>";

这将打印:

session1

Array
(
    [name] => 1
)

session2

Array
(
    [name] => 2
)

session1

Array
(
    [name] => 1
)

session2

Array
(
    [name] => 2
)

session_id是会话的标识符,有助于区分会话。 只是当前会话的命名别名session_name


答案 2

正如对现有答案的评论所表明的那样,提供的解决方案可能并不理想,我想提供一些替代方案。让它成为一个名为 的函数,如下所示:sane_session_name()

function sane_session_name($name)
{
    session_name($name);
    if(!isset($_COOKIE[$name]))
    {
        $_COOKIE[$name] = session_create_id();
    }
    session_id($_COOKIE[$name]);
}

通过在OP的原始代码中使用“理智”的替换,我们得到这个:session_name()

<?php
sane_session_name("session1");
session_start();
$_SESSION["name"] = "1";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

sane_session_name("session2");
session_start();
$_SESSION["name"] = "2";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

sane_session_name("session1");
session_start();
echo "<pre>", print_r($_SESSION, 1), "</pre>";

并且它将产生所需的输出:

Array
(
    [name] => 1
)

Array
(
    [name] => 2
)

Array
(
    [name] => 1
)

有什么不同?

为了指出这个答案和突袭者的答案之间的区别:

  • raidenace的答案中,为网站所有访问者共享的所有客户端创建了两个会话。
  • 有了这个答案,为网站的每个访问者创建了两个会话。因此,这将允许在超全球中为访问者Alice和Bob存储不同的内容,而在另外两个网站访问者Alice中,Bob将“共享数据”,并且毫无意义地每次设置以值setac2命名的cookie并来回发送。$_SESSIONPHPSESSID

安全

为了保护那些“多个(每个用户)会话”免受会话固定会话劫持,我们可以进一步使用此litte功能

function sane_session_start($name)
{
    ini_set("session.use_strict_mode",true);
    ini_set("session.cookie_httponly",true);
    session_name($name);
    if(!isset($_COOKIE[$name]))
    {
        $_COOKIE[$name] = session_create_id();
    }
    session_id($_COOKIE[$name]);
    session_start();
    session_regenerate_id(true);
    $_COOKIE[$name] = session_id();
}

并使OP的代码如下所示:

<?php
sane_session_start("session1");
$_SESSION["name"] = "1";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

sane_session_start("session2");
$_SESSION["name"] = "2";
echo "<pre>", print_r($_SESSION, 1), "</pre>";
session_write_close();

sane_session_start("session1");
echo "<pre>", print_r($_SESSION, 1), "</pre>";

推荐