php清空session值_php注销session变量和销毁session详细分析
當使用完一個session變量后,可以將其刪除,當完成一個會話后,也可以將其銷毀。如果用戶想退出WEB系統,就需要為他提供一個注銷的功能,把他的所有信息在服務器中銷毀。銷毀和當前session有關的所有的資料,可以調用session_destory函數結束當前的會話,并情況當前會話的所有資源。該函數的語法格式如下所示:
bool session_destory(void) //銷毀當前session有關的所有資料。
相對于session_start()函數,該函數用來關閉session的運作,如果成功則返回true,銷毀session資料失敗則返回false。但該函數并不會釋放當前session相關的變量。也不會刪除保存在客戶端cookie中的session id。因為$_SESSION數組和自定義的數組在使用上是相同的,所以我們可以使用unset()函數來釋放在session中注冊的單個變量。如下所以:
unset($_SESSION['username']); //刪除在session中注冊的用戶名變量
unset($_SESSION['password']); //刪除在session中注冊的用戶密碼變量
/* http://www.manongjc.com/article/1286.html */
一定要注意,不要使用unset($_SESSION)刪除整個$_SESSION數組,這樣將不能再通過$_SESSION超全局數組注冊變量了,那如果想要把某個用戶在session中注冊的所有變量都刪除,該如何操作呢?我們可以將數組變量$_SESSION賦值一個空數組。如下所示:
$_SESSION=array(); //將某個用戶在session中注冊的變量全部刪除。
php默認的session是基于cookie的,session id被服務器存儲在客戶端的cookie中,所以在注銷session時也需要清除cookie中保存的session id,而完成這一項工作必須借助setCookie函數完成。在cookie中,保存session id的cookie標示名稱就是session的名稱,這個名稱是在php.ini中通過session.name設置的,在php中,我們可以通過session_name()函數獲取session名稱。刪除session id的代碼如下:
if(isset($_COOKIE[session_name()])){ //判斷cookie中是否保存session id
setcookie(session_name(),'',time()-3600); //刪除包含session id的cookie
}
?>
總結:
php注銷session變量和銷毀session注意事項:
session_destory()可以銷毀session會話,但它不會釋放session變量,我們需要使用unset函數釋放session變量
使用unset函數釋放所有session變量時,不能使用unset($_SESSION),而應該使用$_SESSION=array();
使用session_destory()銷毀seesion會話時,我們還必須使用setcookie函數刪除保存在客戶端cookie里的session id
總結
以上是生活随笔為你收集整理的php清空session值_php注销session变量和销毁session详细分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 几款不错的Android开源APP效果展
- 下一篇: 评估方法(交叉验证法、自助法、留出法)