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