PHP中session_unset()和session_destroy()的区别是什么
内容导读
收集整理的这篇技术教程文章主要介绍了PHP中session_unset()和session_destroy()的区别是什么,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2896字,纯文字阅读大概需要5分钟。
内容图文
在PHP中有两个非常相似的函数session_unset()和session_destroy(),它们两者都是用于删除注册到会话的所有变量,那么它们之间有什么差异?下面本篇文章就来给大家介绍一下session_unset()和session_destroy()的区别,希望对大家有所帮助。【视频教程推荐:PHP教程】session_unset()函数
session_unset()函数只删除会话中的变量,会话仍然存在;它仅会截断数据。
基本语法:
session_unset( void )
session_destroy()函数
session_destroy()函数会销毁与当前会话关联的所有数据;但它不会取消设置与会话关联的任何全局变量,也不会取消设置会话cookie。
基本语法:
session_destroy( void )
session_unset()和session_destroy()的区别
下面通过代码示例来看看session_unset()和session_destroy()的区别
首先使用session.php文件保存会话
<?php header("content-type:text/html;charset=utf-8");// 启动会话session_start(); //显示会话IDecho session_id(); // 检查会话名称是否存在if( isset($_SESSION['name']) ) { echo '<br>' . '会话还有效.'; } else { echo '<br>' . '会话已销毁'; } $_SESSION['name'] = 'PHP中文网!'; $_SESSION['website'] = 'www.gxlcms.com' ; ?>
输出:
示例1:使用session_unset()函数
在使用session_unset()函数之前,先会显示name和website。
<?php header("content-type:text/html;charset=utf-8");// 启动会话session_start(); // 检查会话名称是否存在if( isset($_SESSION['name']) ) { echo '<br>' . '会话还有效'.'<br>'; } else { echo '<br>' . '会话已销毁'; } echo $_SESSION['name'].'<br>'; echo $_SESSION['website'].'<br>'; ?>
输出:
使用session_unset()函数后,它破坏了正在使用的'name'和'website'之类的变量。
<?php header("content-type:text/html;charset=utf-8");// 启动会话session_start(); // 检查会话名称是否存在if( isset($_SESSION['name']) ) { echo '<br>' . '会话还有效'.'<br>'; } else { echo '<br>' . '会话已销毁'; } echo $_SESSION['name'].'<br>'; echo $_SESSION['website'].'<br>'; // 使用session_unset()函数session_unset(); ?>
输出:
示例2:使用session_destroy()函数
session_destroy()函数会破坏整个会话而不是破坏变量。调用session_start()时,PHP会在浏览器中设置会话cookie。我们还需要删除cookie以完全破坏会话。
<?php header("content-type:text/html;charset=utf-8");// 启动会话session_start(); // 检查会话名称是否存在if( isset($_SESSION['name']) ) { echo '<br>' . '会话还有效'.'<br>'; } else { echo '<br>' . '会话已销毁'; } echo $_SESSION['name'].'<br>'; echo $_SESSION['website'].'<br>'; $_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(); ?>
输出:
说明:执行echo session_id();语句时,可以看到有一个不同的会话ID,这意味着上一个会话已被销毁,所有变量和cookie也已销毁。因为所有变量都被破坏了,所以当检测会话是否存在时会转到else条件输出'会话已销毁'。
注:如果希望终止会话,也请删除会话cookie。这将破坏会话,而不仅仅是会话数据。
以上就是PHP中session_unset()和session_destroy()的区别是什么的详细内容,更多请关注Gxl网其它相关文章!
内容总结
以上是为您收集整理的PHP中session_unset()和session_destroy()的区别是什么全部内容,希望文章能够帮你解决PHP中session_unset()和session_destroy()的区别是什么所遇到的程序开发问题。 如果觉得技术教程内容还不错,欢迎将网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。