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