(o゜▽゜)o☆[BINGO!]
ok,我們先看看cookie是什麼東東?
cookie是服務器留在客戶端的用於識別用戶或者存儲一些數據的小文件(注意,session存儲在服務器端,這是兩者的區別之一)。我們平時登錄某門戶時,會有選項“是否保存登錄”或者“下次自動登錄”,當我們勾選了之後,服務器就會在我們的浏覽器創建cookie文件來保存我們的信息。每當計算機通過浏覽器請求頁面時,它會同時發送cookie。通過PHP,可以創建並取回cookie的值。cookie在web中是很重要的角色,早在網景浏覽器的時候就產生了cookie。cookie經常被用於用戶驗證系統。
1.創建cookie
函數setcookie()可以在PHP中生成cookie。由於cookie是HTTP頭標部分的內容,因此必須在輸出任何數據之前調用setcookie(),這個限制和header()類似,定義:
1 bool setcookie( string name[,string value][,int expire][,string path][,string domain][,bool secure][,bool httponly])
好多參數啊!Σ(⊙▽⊙"a 不急,讓我們看看各個參數的作用:
name : 必選,表示cookie的名字。
value : 可選,表示cookie值,存儲在客戶端,當為空時,表示撤銷客戶端中該cookie的資料(這樣可以刪除cookie)。
expire : 可選,表示cookie的有效截止時間,也就是過期時間,如果沒有指定或者指定為0,那麼通常是在關閉浏覽器時失效。
path : 可選,cookie有效路徑。
domain : 可選,cookie有效域名。
secure : 表示在HTTPS的安全傳輸時才有效。
實例(建立一個名字為test,值為China的cookie):
1 <?php 2 setcookie("test",China"); 3 ?>
使用setcookie()給的值只能是數字或者字符串,不能是其他的復雜結構。
2.獲取cookie
創建cookie後,就可以使用預定義變量$_COOKIE來獲取cookie。不過,只能在其他頁面獲取cookie,因為在php中,被設置的cookie不會在本頁面生效,除非該頁面被刷新。
實例:
1 <?php 2 setcookie("test","China"); 3 echo "cookie is ".$_COOKIE["test"]; 4 ?>
這裡之所以要刷新頁面,是因為cookie的值不會在調用setcookie()之後立即存儲在$_COOKIE變量中,而是隨著http請求被發送至服務器,這時候cookie 的值才會出現在$_COOKIE中。
3.cookie的有效期
cookie有生命周期,也就是cookie存在的有效時間。可以設置第三個參數來設置有效時間。
實例(設置cookie有效時間的幾種方式):
1 setcookie("cookie_one","A",time()+60*60); //cookie在一小時後失效 2 setcookie("cookie_two","B",time()+60*60*24); //cookie在一天後失效 3 setcookie("cookie_three","C",mktime(23,53,19,10,09,2020)); //cookie在2020年10月9日23時53分19秒失效 4 setcookie("cookie_four","D"); //關閉浏覽器後cookie失效
4.cookie的有效路徑
cookie中的路徑用來控制設置的cookie在哪個路徑下有效,默認為'/',在所有路徑下都有效,也就是在整個服務器域名下都有效,當設定了其他路徑之後,則只在設定的路徑以及子路徑下有效,例如:
1 setcookie('test', time(), 0, '/path');
上面的設置會使test在/path以及子路徑/path/abc下都有效,但是在根目錄下就讀取不到test的cookie值。
一般情況下,大多是使用所有路徑的,只有在極少數有特殊需求的時候,會設置路徑,這種情況下只在指定的路徑中才會傳遞cookie值,可以節省數據的傳輸,增強安全性以及提高性能。
5.刪除cookie
刪除cookie比較簡單,也是通過setcookie()來實現的(不要使用unset()!!!)下面的代碼就是個簡單例子:
1 setcookie("test","");
通過將第二個參數設為空來達到刪除cookie的目的。如果設置cookie時,為cookie提供了特定的值,那麼在刪除cookie時,仍然需要提供這些參數,以便PHP可以正確地刪除cookie。