您好,登錄后才能下訂單哦!
這篇文章主要介紹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' ; ?>
輸出:
示例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()的區別有哪些的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。