温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

PHP中session_unset()和session_destroy()的区别有哪些

发布时间:2020-09-09 10:16:32 来源:亿速云 阅读:204 作者:小新 栏目:编程语言

这篇文章主要介绍PHP中session_unset()和session_destroy()的区别有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

在PHP中有两个非常相似的函数session_unset()和session_destroy(),它们两者都是用于删除注册到会话的所有变量。

PHP中session_unset()和session_destroy()的区别有哪些

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(); 
  
//显示会话ID
echo session_id(); 
  
// 检查会话名称是否存在
if( isset($_SESSION['name']) ) { 
    echo '<br>' . '会话还有效.'; 
} 
else { 
    echo '<br>' . '会话已销毁'; 
} 
  
$_SESSION['name'] = '亿速云!'; 
$_SESSION['website'] = 'www.php.cn' ; 
  
?>

输出:

PHP中session_unset()和session_destroy()的区别有哪些

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

输出:

PHP中session_unset()和session_destroy()的区别有哪些

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

输出:

PHP中session_unset()和session_destroy()的区别有哪些

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

PHP中session_unset()和session_destroy()的区别有哪些

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

以上是PHP中session_unset()和session_destroy()的区别有哪些的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI