您好,登錄后才能下訂單哦!
小編給大家分享一下php如何刪除cookie,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
php刪除cookie的方法:首先創建一個PHP示例文件;然后通過語句“setcookie("TestCookie", "", time() - 3600);”將過期時間設為一小時前即可實現刪除設置的cookie。
php 刪除cookie
我們先來看下相關cookie的機制。
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
要刪除cookie需要確保它的失效期是在過去,才能觸發瀏覽器的刪除機制。
下面的例子說明了如何刪除剛才設置的cookie:
//將過期時間設為一小時前 setcookie("TestCookie", "", time() - 3600); setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1); ?>
刪除一個cookie的方法就是把這個cookie的有效期設置為當前時間以前,這也是幾乎所有php程序員都會這么做。()
后來一個初接觸php的朋友告訴我,他在程序中本想把一個cookie的值設置為空,結果導致這個cookie直接被刪除。我當時的第一反應是不相信,于是測試了一下:
setcookie("testcookie", ''); print_r($_COOKIE);
結果果然是整個$_COOKIE數組都是空的,而非僅僅$_COOKIE['testcookie']為空。于是用winsock抓包,觀察返回的http頭,發現http頭竟然是“Set-Cookie: testcookie=deleted; expires=Mon, 18-Jun-2007 02:42:33 GMT”,這說明“setcookie("testcookie", '');”的的確確是將testcookie這個cookie直接刪除,而關于這種情況在php手冊中完全沒有說明。
最后閱讀php源碼,終于發現真相(這就是開源的好處了,有什么不清楚的內幕,直接查源碼)。
以下代碼可以在php5.20的linux源碼包中ext/standard/head.c第99行附近找到:
if (value && value_len == 0) { /* * MSIE doesn't delete a cookie when you set it to a null value * so in order to force cookies to be deleted, even on MSIE, we * pick an expiry date 1 year and 1 second in the past */ time_t t = time(NULL) - 31536001; dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, t, 0 TSRMLS_CC); sprintf(cookie, "Set-Cookie: %s=deleted; expires=%s", name, dt); efree(dt); } else { sprintf(cookie, "Set-Cookie: %s=%s", name, value ? encoded_value : ""); if (expires > 0) { strcat(cookie, "; expires="); dt = php_format_date("D, d-M-Y H:i:s T", sizeof("D, d-M-Y H:i:s T")-1, expires, 0 TSRMLS_CC); strcat(cookie, dt); efree(dt); } }
源碼中清清楚楚的顯示“if (value && value_len == 0)”,當“value_len”為0時,“sprintf(cookie, "Set-Cookie: %s=deleted; expires=%s", name, dt);”會發送刪除cookie的http頭給瀏覽器。
最后我們可以得出結論:在php中使用“setcookie($cookiename, '');”或者“setcookie($cookiename, NULL);”都會刪除cookie,當然這些手冊中并沒有。
看完了這篇文章,相信你對“php如何刪除cookie”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。