php中session_destroy()的作用?
它会destroys all of the data associated with the current session,但是它既不注销变量,又不注销session cookie。那它做了什么?还有这个函数有什么用呢? 展开
Session_destroy()销毁当前会话中的所有数据,但不重置与当前会话关联的全局变量,也不重置会话cookie。如果需要再次使用会话变量,则必须再次调用session_start()函数。
为了完全销毁会话,例如当用户注销时,必须同时重置会话ID。如果会话ID是由cookie传递的,那么还会调用setcookie()函数来删除客户机的会话cookie。
使用方法:
1.要在PHP中使用会话,首先需要启动会话。要启动会话,您需要使用PHP的内置函数session_start(),如图所示。
2. 然后,session_start()函数必须位于< HTML >标记之前,如下所示。
3.启动会话后,使用PHP的内置数组对象源$_SESSION[]来存储数百个,并创建一个新的index.php文件。
4.在index.php文件中,键入以下代码将内容存储到会话中。
5.存储结束后即可,只需将键值取出即可使用[echo$_SESSION['views']]命令。
6.在浏览器中输入localhost:8080/jingyan/firmssy/index。在PHP中,您可以查看$_SESSION变量中的值。
session_destroy() 销毁当前会话中的全部数据, 但是不会重置当前会话所关联的全局变量, 也不会重置会话 cookie。 如果需要再次使用会话变量, 必须重新调用 session_start() 函数。
为了彻底销毁会话,比如在用户退出登录的时候,必须同时重置会话 ID。 如果是通过 cookie 方式传送会话 ID 的,那么同时也需要 调用setcookie() 函数来 删除客户端的会话 cookie。
范例
<?php
// 初始化会话。
// 如果要使用会话,别忘了现在就调用:
session_start();
// 重置会话中的所有变量
$_SESSION = array();
// 如果要清理的更彻底,那么同时删除会话 cookie
// 注意:这样不但销毁了会话中的数据,还同时销毁了会话本身
if (ini_get("session.use_cookies")) {
$params = session_get_cookie_params();
setcookie(session_name(), '', time() - 42000,
$params["path"], $params["domain"],
$params["secure"], $params["httponly"]
);
}
// 最后,销毁会话
session_destroy();
?>
如果您希望删除某些 session 数据,可以使用 unset() 或 session_destroy() 函数。
unset() 函数用于释放指定的 session 变量:
<?php
unset($_SESSION['views']);
?>
您也可以通过 session_destroy() 函数彻底终结 session:
<?php
session_destroy();
?>
注释:session_destroy() 将重置 session,您将失去所有已存储的 session 数据。