0

我进行了广泛的搜索,虽然我发现了很多关于管理 PHP 会话到期时间的问题,但我没有发现任何与我提出的方法有关的问题。我有工作代码,但想通过这个社区传递它,看看是否有任何不可预见的问题或潜在的利用。提前感谢您的反馈。

本质上,一旦设置了购物车会话,页面将开始每 10 分钟不活动刷新一次。一旦总经过的时间(因为设置了会话)超过 30 分钟,用户将被重定向到破坏所有会话的页面。

if (isset($_SESSION["shopping_cart"])) {

    echo '<meta http-equiv="refresh" content="600" />';

    if (!isset($_SESSION['timer'])) {
        $_SESSION['timer'] = time();
    }

    $now = time();
    $elapsed = $now - $_SESSION['timer'];

    if ($elapsed > 1800) {
        header('Location: session_reset.php');
        exit();
    }

}
4

1 回答 1

0

我没有看到您的代码有问题,它每 10 分钟检查一次会话时间是否超过 30 分钟,以及是否有重定向以终止会话。

不知道你为什么要这样做?也许将用户购物篮存储在 cookie 或本地存储中,然后终止会话并留下通知 - 嘿,用户很抱歉您的会话超时,但不要担心我们已将您的购物篮保存在这里....

于 2021-05-10T20:59:04.980 回答