php中session_unset与session_destroy的用法与区别,做退出的执行顺序
更新:HHH   时间:2023-1-7


区别:

session_unset()释放当前在内存中已经创建的所有$_SESSION变量,但不删除session文件以及不释放对应的session id

session_destroy()删除当前用户对应的session文件以及释放session id,内存中的$_SESSION变量内容依然保留

因此,释放用户的session所有资源,需要顺序执行如下代码:

<?php
$_SESSION['user'] = ‘user1′;
session_unset();
session_destroy();
?>

总结:

session_destroy是注销所有的session变量,并且结束session会话; 
session_unset()并不注销session变量,但把所有的session变量的值清空.

退出代码的操作:

    public function loginOut() {

        setcookie("$this->loginMarked", NULL, -3600, "/");

        unset($_SESSION["$this->loginMarked"], $_COOKIE["$this->loginMarked"]);

        if (isset($_SESSION[C('USER_AUTH_KEY')])) {

            unset($_SESSION[C('USER_AUTH_KEY')]);

            unset($_SESSION);

            session_destroy();

        }

        $this->redirect("Index/index");

    }



返回web开发教程...