本篇文章主要介紹php三種清空session的方式,感興趣的朋友參考下,希望對大家有所協助。
session刪除清空是很講究了如果我們定義好可以清除指定變數否則不小心會把所有session都清除掉了,下面我們來看一些總結。
第一種方式:unset($_SESSION['xxx']) 刪除單個session,unset($_SESSION['xxx']) 用來unregister一個登入的session變數。
其作用和session_unregister()相同。
session_unregister()在PHP5中已經廢棄。
php 官方刪除session方式
<?php // 初始化session. session_start(); /*** 刪除所有的session變數..也可用unset($_SESSION[xxx])逐個刪除。****/ $_SESSION = array(); /***刪除sessin id.由於session預設是基於cookie的,所以使用setcookie刪除包含session id的cookie.***/ if (isset($_COOKIE[session_name()])) { setcookie(session_name(), '', time()-42000, '/'); } // 最後徹底銷毀session. session_destroy();?>
unset($_SESSION) 此函數千萬不可使用,它會將全域變數$_SESSION銷毀,而且還沒有可行的辦法將其恢複。使用者也不再可以註冊$_session變數。
第二種方式:session_unset() 或者 $_SESSION=array() 刪除多個session
第三種方式:session_destroy()結束當前的會話,並清空會話中的所有資源。該函數不會unset(釋放)和當前session相關的全域變數(globalvariables),也不會刪除用戶端的session cookie.PHP預設的session是基於cookie的,如果要刪除cookie的話,必須藉助setcookie()函數。
小結:
session_destroy是登出所有的session變數,並且結束session會話;
如果希望刪除一些session資料,則可以使用unset()函數或session_destroy()函數。unset()函數的作用是釋放指定的session變數,調用格式如下:
<?phpunset($_SESSION['jugelizi']);?>
session_destroy()函數的作用是將session全部刪除,調用格式如下:
<?PHP session_destroy(); ?>
提示:session_destroy()會重新設定session,你會丟失所有已儲存的session資料。
session_unset()並不登出session變數,但把所有的session變數的值清空。
總結:以上就是本篇文的全部內容,希望能對大家的學習有所協助。
相關推薦:
PHP 實現的將圖片轉換為ASCII碼
PHP中的switch語句的用法
php程式中擷取漢字拼音的首字母的方法