PHP Cookie
PHP?Cookie
cookie 常用來辨識(shí)使用者。
Cookie 是什麼?
Cookie是由伺服器端生成,傳送給User-Agent(一般是瀏覽器),瀏覽器會(huì)將Cookie的key/value儲(chǔ)存到某個(gè)目錄下的文字檔案內(nèi),下次要求同一網(wǎng)站時(shí)就發(fā)送該Cookie給伺服器(前提是瀏覽器設(shè)定為啟用cookie)。 Cookie名稱和值可以由伺服器端開發(fā)自己定義,這樣伺服器可以知道該使用者是否是合法使用者以及是否需要重新登入等,伺服器可以設(shè)定或讀取Cookies中包含信息,藉此維護(hù)使用者跟伺服器會(huì)話中的狀態(tài)
如何建立Cookie?
setcookie() 函數(shù)用於設(shè)定 cookie。
註解:setcookie() 函數(shù)必須位於 <html> 標(biāo)籤之前。
語(yǔ)法
setcookie(name, value, expire, path, domain);
實(shí)例1
在下面的範(fàn)例中,我們將建立名為"user" 的cookie,並為它賦值"runoob"。我們也規(guī)定了此 cookie 在一小時(shí)後過期:
<?php setcookie("user", "runoob", time()+3600); ?> <html> .....
註解:在傳送 cookie 時(shí),cookie 的值會(huì)自動(dòng)進(jìn)行 URL 編碼,在取回時(shí)會(huì)自動(dòng)解碼。 (為防止 URL 編碼,請(qǐng)使用 setrawcookie() 取代。)
實(shí)例 2
您也可以透過另一種方式設(shè)定 cookie 的過期時(shí)間。這也許比使用秒錶示的方式簡(jiǎn)單。
<?php $expire=time()+60*60*24*30; setcookie("user", "runoob", $expire); ?> <html> .....
在上面的實(shí)例中,過期時(shí)間被設(shè)定為一個(gè)月(60 秒 * 60 分 * 24 小時(shí) * 30 天)。
Cookie的設(shè)定與應(yīng)用
Setcookie(string name, string value, int expire,string path, string domain, intsecure); 其中name是cookie變數(shù)名稱標(biāo)識(shí),你在php中將能像使用普通變數(shù)名稱相同來用他引用
cookie變數(shù)。 value是cookie變數(shù)的初始值,expire 表示該cookie變數(shù)的有效時(shí)間;path 為該cookie變數(shù)的相關(guān)路徑;domain 表示cookie變數(shù)的網(wǎng)站;secure 則需在 https的安全傳輸時(shí)才有效。
SetCookie("Cookie", "cookievalue",time()+3600, "/forum", ".365shequ.com", 1);???
名稱,必須??? 值,且必須????
名稱,必須??? 值time()+3600=1小時(shí)??? 儲(chǔ)存路徑??? 儲(chǔ)存的網(wǎng)域??? HTTPS
PHP讀取Cookie
使用超全域變數(shù)$_COOKIE陣列可以讀取到目前客戶端中儲(chǔ)存的Cookie新建PHP檔案set_cookie.php
程式碼為
echo?$_COOKIE['foo'];
#檢查Cookie是否已經(jīng)設(shè)定成功為Cookie設(shè)定過期時(shí)間
第三個(gè)參數(shù)為unix的時(shí)間戳
0 默認(rèn)值,關(guān)閉瀏覽器即失效
time() + 86400 一天
setcookie('foo',?'a',?time()?+?86400);
#設(shè)定後請(qǐng)關(guān)閉瀏覽器,再次開啟瀏覽器並訪問,檢查Cookie是否存在
#為Cookie設(shè)定路徑######
setcookie('bar',?'b',?time()?+?86400,?'/uploads');
??????? 請(qǐng)測(cè)試/目錄下的PHP頁(yè)面中是否可以讀取到名為bar的Cookie
??????? 請(qǐng)測(cè)試/uploads下的PHP頁(yè)面中是否可以讀取到名為foo的Cookie
??????? 請(qǐng)新另一個(gè)子目錄,測(cè)試在子目錄中的PHP頁(yè)面能讀取到哪些Cookie
一旦設(shè)定了Path,那麼該P(yáng)ath下的Cookie只有該P(yáng)ath下的頁(yè)面可以讀取到
為Cookie設(shè)定網(wǎng)域名稱
setcookie('key',?'val',?time()?+?86400,?'/uploads',?'.your.domain');
#設(shè)定域?yàn)閚ews. php.cn的Cookie,是無法被sports.365jia.cn下的頁(yè)面讀取到的,反之亦然
若想讓所有二級(jí)域名共享Cookie需要將域設(shè)置為.php.cn
Cookie的限制問題
很多瀏覽器對(duì)Cookie的數(shù)量是有限制的,大多數(shù)瀏覽器規(guī)定一個(gè)網(wǎng)站可以設(shè)定的Cookie數(shù)量是不可以超過50個(gè)的,部分瀏覽器甚至限制為30個(gè)
瀏覽器對(duì)Cookie的尺寸也有限制,一般不得超過4K大小
Cookie的安全問題
如果在網(wǎng)咖上網(wǎng)後沒有關(guān)機(jī),其他人使用你的電腦後是可以查看到你訪問的所有的網(wǎng)站歷史記錄以及網(wǎng)站保存的Cookie內(nèi)容的,如果重要的資料(使用者名稱、密碼、卡片號(hào)碼、手機(jī)號(hào)碼、身分證字號(hào)…)保存在Cookie中是非常危險(xiǎn)的行為。
因此,重要資料不能存放在Cookie裡,如果一定要保存還是得靠伺服器
#cookie注意事項(xiàng)
##不同的電腦無法共享Cookie同一臺(tái)電腦中的不同的瀏覽器也無法共用Cookie同一個(gè)瀏覽器不同的網(wǎng)域下還是無法共用Cookie甚至是同一個(gè)瀏覽器、在同一個(gè)網(wǎng)域下,不同路徑的Cookie也無法實(shí)現(xiàn)共享如何取回Cookie 的值?
PHP 的 $_COOKIE 變數(shù)用來取回 cookie 的值。 在下面的實(shí)例中,我們?nèi)』亓嗣麨?user" 的cookie 的值,並把它顯示在了頁(yè)面上:<?php // 輸出 cookie 值 echo $_COOKIE["user"]; // 查看所有 cookie print_r($_COOKIE); ?>在下面的實(shí)例中,我們使用isset() 函數(shù)來確認(rèn)是否已設(shè)定了cookie:
<html> <head> <meta charset="utf-8"> <title> php中文網(wǎng)(php.cn)</title> </head> <body> <?php if (isset($_COOKIE["user"])) echo "歡迎 " . $_COOKIE["user"] . "!<br>"; else echo "普通訪客!<br>"; ?> </body> </html>?
#如何刪除Cookie?
當(dāng)刪除 cookie 時(shí),您應(yīng)使過期日期變更為過去的時(shí)間點(diǎn)。 刪除的實(shí)例:<?php // 設(shè)置 cookie 過期時(shí)間為過去 1 小時(shí) setcookie("user", "", time()-3600); ?>?
如果瀏覽器不支援 Cookie 該怎麼辦?
如果您的應(yīng)用程式需要與不支援 cookie 的瀏覽器打交道,那麼您必須使用其他的方法在您的應(yīng)用程式中的頁(yè)面之間傳遞資訊。一種方式是透過表單傳遞資料(有關(guān)表單和使用者輸入的內(nèi)容,在本教學(xué)的前面章節(jié)中我們已經(jīng)介紹過了)。下面的表單在使用者單點(diǎn)擊"Submit" 按鈕時(shí),向"welcome.php" 提交了使用者輸入:
<html> <head> <meta charset="utf-8"> <title> php中文網(wǎng)(php.cn)</title> </head> <body> <form action="welcome.php" method="post"> 名字: <input type="text" name="name"> 年齡: <input type="text" name="age"> <input type="submit"> </form> </body> </html>
取回"welcome.php" 檔案中的值,如下所示:
<html> <head> <meta charset="utf-8"> <title>php中文網(wǎng)(php.cn)</title> </head> <body> 歡迎 <?php echo $_POST["name"]; ?>.<br> 你 <?php echo $_POST["age"]; ?> 歲了。 </body> </html>
?
慢半拍
#實(shí)際開發(fā)中往往會(huì)犯的一個(gè)錯(cuò)誤就是setcookie後,直接透過$_COOKIE去取得資料
setcookie('foo',?1);
print_r($_COOKIE);
echo?$_COOKIE['foo'];
#上面的情況下,是無法取得到剛剛設(shè)定的Cookie的,這就是我們標(biāo)題裡說的慢半拍的問題.
?
原理很簡(jiǎn)單,Cookie實(shí)際上最終是保存到瀏覽器中的,只有目前頁(yè)面回到瀏覽器後,setcookie的值才會(huì)儲(chǔ)存到瀏覽器裡,在頁(yè)面第二次造訪的時(shí)候,PHP才能讀取到瀏覽器的Cookie裡的資料
而$_COOKIE中的資料則是每次頁(yè)面請(qǐng)求的時(shí)候從客戶端帶給伺服器的
這就是為什麼當(dāng)時(shí)設(shè)置,當(dāng)時(shí)取不到的原因
解決慢半拍的一個(gè)方法就是存值之後程式立即刷新頁(yè)面.