您好,登錄后才能下訂單哦!
這篇“php cookie刪除不了的解決辦法”除了程序員外大部分人都不太理解,今天小編為了讓大家更加理解“php cookie刪除不了的解決辦法”,給大家總結了以下內容,具有一定借鑒價值,內容詳細步驟清晰,細節處理妥當,希望大家通過這篇文章有所收獲,下面讓我們一起來看看具體內容吧。
php cookie刪除不了的解決辦法:首先創建一個PHP示例文件;然后通過setcookie創建cookie;最后把這個cookie的有效期設置為當前時間以前的時間即可清除創建的cookie。
PHP無法刪除COOKIE?設置COOKIE有效期
PHP 透明地支持 HTTP cookie, cookie是一種在遠程瀏覽器端存儲數據并以此來跟蹤和識別用戶的機制。可以用setcookie() 或 setrawcookie()函數來設置cookie, cookie是HTTP標頭的一部分,因此 setcookie()函數必須在其他信息被輸出到瀏覽器前調用,這和對header()函數的限制類似。
setcookie();
刪除cookie的方法是把這個cookie的有效期設置為當前時間以前
setcookie('test', 'true', time() + 300); // 創建 cookie //setcookie('test',time() - 3600 ); // 清除建立的 cookie //setcookie('test'); //只是將 $_COOKIE['test'] 的值清空 如果直接setcookie('test', ''); echo ''; print_r($_COOKIE); //attay();
會發現$_COOKIE數組是空的,而非僅僅$_COOKIE['test'] 為空,于是winsock抓包,觀察返回的http 頭,竟然是:
set-cookie:test=deleted; expires=Mon, 29-May-2014 10:22:15 GMT
登陸:
setcookie('username', 'zhangsan', time()+1000, "/php100");
退出:
setcookie('username', '', time()-3600);
發現做退出時 在IE下沒問題,但是在Firefox中測試,登陸正常,無法退出,查看IE、Firefox中cookie記錄的區別,經過測試才發現原來沒有指定 setcookie()的第四個參數(合法路徑參數),所以導致登陸和退出時所設置cookie的路徑不同(Firefox比較嚴格,導致又重新建了各變量)
例:
$value = 'something'; setcookie('TestCookie', $value, time() + 3600); setcookie('mytest', $value, time() + 3600, "~rasmus", ".maoge.com", 1); if (isset($_COOKIE['TestCookie'])) { echo 'TestCookie :' . $_COOKIE['TestCookie']; }
感謝你的閱讀,希望你對“php cookie刪除不了的解決辦法”這一關鍵問題有了一定的理解,具體使用情況還需要大家自己動手實驗使用過才能領會,快去試試吧,如果想閱讀更多相關知識點的文章,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。