首页 > 编程 > PHP > 正文

PHP中session_unset()和session_destroy()的区别是什么

2020-03-22 16:34:07
字体:
来源:转载
供稿:网友
在PHP中有两个非常相似的函数session_unset()和session_destroy(),它们两者都是用于删除注册到会话的所有变量,那么它们之间有什么差异?下面本篇文章就来给大家介绍一下session_unset()和session_destroy()的区别,希望对大家有所帮助。【视频教程推荐:PHP教程】

session_unset()函数

session_unset()函数只删除会话中的变量,会话仍然存在;它仅会截断数据。

基本语法:

session_unset( void )

session_destroy()函数

session_destroy()函数会销毁与当前会话关联的所有数据;但它不会取消设置与会话关联的任何html' target='_blank'>全局变量,也不会取消设置会话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.VeVb.com ? 

输出:

2.jpg

示例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 ? 

输出:

3.jpg

使用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(); ? 

输出:

4.jpg

示例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(); ? 

输出:

5.jpg

说明:执行echo session_id();语句时,可以看到有一个不同的会话ID,这意味着上一个会话已被销毁,所有变量和cookie也已销毁。因为所有变量都被破坏了,所以当检测会话是否存在时会转到else条件输出 会话已销毁 。

6.jpg

注:如果希望终止会话,也请删除会话cookie。这将破坏会话,而不仅仅是会话数据。

以上就是PHP中session_unset()和session_destroy()的区别是什么的详细内容,PHP教程

郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表