很多朋友在使用setcookie設置值為空或NULL時系統會自動把cookie給刪除掉,下面我來給大家分析cookie值為null或空字符串刪除cookie原因吧,有需要學習的朋友可參考。
官方文檔中也是這樣寫的:
#2 setcookie() delete example
<?php
// set the expiration date to one hour ago
setcookie ("TestCookie", "", time() - 3600);
setcookie ("TestCookie", "", time() - 3600, "/~rasmus/", "example.com", 1);
?>
今天遇到一件奇怪的事, 在setcookie的時候,傳了一個空字符串給$value,結果竟然是此cookie被刪除了…
代碼如下 復制代碼$name = "post_url";
$value = "";
setcookie($name, $value, time()+60*60*3, "/" );
去翻php 5.4.13 的源碼結果得知
參數中的value在C語言中的類型是char * , 還有一個 value_len標明了它的長度。
如果value_len為0的話,就寫了下面的cookie:
值為”deleted”, 過期時間為 Thu, 01-Jan-1970 08:00:01 CST 或者說是 Thu, 01-Jan-1970 00:00:01 GMT
看來setcookie($name, “”) 確實可以刪除這個cookie了…
同理,在php中,strval(NULL) === “” , 所以 setcookie($name, NULL) 也就相當於 setcookie($name, “”),同樣可以刪除此cookie.