溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

PHP中session_unset()和session_destroy()的區(qū)別有哪些

發(fā)布時間:2020-09-09 10:16:32 來源:億速云 閱讀:218 作者:小新 欄目:編程語言

這篇文章主要介紹PHP中session_unset()和session_destroy()的區(qū)別有哪些,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

在PHP中有兩個非常相似的函數(shù)session_unset()和session_destroy(),它們兩者都是用于刪除注冊到會話的所有變量。

PHP中session_unset()和session_destroy()的區(qū)別有哪些

session_unset()函數(shù)

session_unset()函數(shù)只刪除會話中的變量,會話仍然存在;它僅會截斷數(shù)據(jù)。

基本語法:

session_unset( void )

session_destroy()函數(shù)

session_destroy()函數(shù)會銷毀與當前會話關聯(lián)的所有數(shù)據(jù);但它不會取消設置與會話關聯(lián)的任何全局變量,也不會取消設置會話cookie。

基本語法:

session_destroy( void )

session_unset()和session_destroy()的區(qū)別

下面通過代碼示例來看看session_unset()和session_destroy()的區(qū)別

首先使用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()的區(qū)別有哪些

示例1:使用session_unset()函數(shù)

在使用session_unset()函數(shù)之前,先會顯示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()函數(shù)后,它破壞了正在使用的'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()函數(shù)
session_unset(); 
?>

輸出:

PHP中session_unset()和session_destroy()的區(qū)別有哪些

示例2:使用session_destroy()函數(shù)

session_destroy()函數(shù)會破壞整個會話而不是破壞變量。調(diào)用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。
// 注意:這將破壞會話,而不僅僅是會話數(shù)據(jù)!
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()的區(qū)別有哪些

說明:執(zhí)行echo session_id();語句時,可以看到有一個不同的會話ID,這意味著上一個會話已被銷毀,所有變量和cookie也已銷毀。因為所有變量都被破壞了,所以當檢測會話是否存在時會轉(zhuǎn)到else條件輸出'會話已銷毀'。

PHP中session_unset()和session_destroy()的區(qū)別有哪些

注:如果希望終止會話,也請刪除會話cookie。這將破壞會話,而不僅僅是會話數(shù)據(jù)。

以上是PHP中session_unset()和session_destroy()的區(qū)別有哪些的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI