PHP Cookie學(xué)習(xí)筆記
什么是Cookie
Cookie是一種在遠(yuǎn)程瀏覽器端存儲(chǔ)數(shù)據(jù)并以此來(lái)跟蹤和識(shí)別用戶的機(jī)制。簡(jiǎn)單地說(shuō),Cookie是Web服務(wù)器暫時(shí)存儲(chǔ)在用戶硬盤上的一個(gè)文本文件,并隨后被Web瀏覽器讀取。當(dāng)用戶再次訪問(wèn)Web網(wǎng)站時(shí),網(wǎng)站通過(guò)讀取Cookies文件記錄這位訪客的特定信息(如上次訪問(wèn)的位置、花費(fèi)的時(shí)間、用戶名和密碼等),從而迅速作出響應(yīng),如在頁(yè)面中不需要輸入用戶的ID和密碼即可直接登錄網(wǎng)站等。
文本文件的命令格式如下:
用戶名@網(wǎng)站地址[數(shù)字].txt
Cookie的功能
Web服務(wù)器可以應(yīng)用Cookies包含信息的任意性來(lái)篩選并經(jīng)常性維護(hù)這些信息,以判斷在HTTP傳輸中的狀態(tài)。Cookie常用于以下3個(gè)方面:
•記錄訪客的某些信息。如可以利用Cookie記錄用戶訪問(wèn)網(wǎng)頁(yè)的次數(shù),或者記錄訪客曾經(jīng)輸入過(guò)的信息,另外,某些網(wǎng)站可以使用Cookie自動(dòng)記錄訪客上次登錄的用戶名。
•在頁(yè)面之間傳遞變量。瀏覽器并不會(huì)保存當(dāng)前頁(yè)面上的任何變量信息,當(dāng)頁(yè)面被關(guān)閉時(shí)頁(yè)面上的所有變量信息將隨之消失。如果用戶聲明一個(gè)變量id=8,要把這個(gè)變量傳遞到另一個(gè)頁(yè)面,可以把變量id以Cookie形式保存下來(lái),然后在下一頁(yè)通過(guò)讀取該Cookie來(lái)獲取變量的值。
•將所查看的Internet頁(yè)存儲(chǔ)在Cookies臨時(shí)文件夾中,可以提高以后瀏覽的速度。
創(chuàng)建Cookie
在PHP中通過(guò)setcookie()函數(shù)創(chuàng)建Cookie。語(yǔ)法格式如下:
讀取Cookie
在PHP中可以直接通過(guò)超級(jí)全局?jǐn)?shù)組$_COOKIE[]來(lái)讀取瀏覽器端的Cookie值。
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>PHP語(yǔ)言基礎(chǔ)</title> </head> <body> <?php date_default_timezone_set("PRC"); header("Content-Type:text/html; charset=gb2312"); if (!isset($_COOKIE["visittime"])) { setcookie("visittime", date("y-m-d H:i:s")); echo "這是第一次保存Cookie"."<br>"; } else { setcookie("visittime", date("y-m-d H:i:s"), time() + 60); echo "上次訪問(wèn)時(shí)間為:" . $_COOKIE["visittime"]; echo "<br>"; } echo "本次訪問(wèn)時(shí)間:" . date("y-m-d H:i:s"); ?> </body> </html>
第一次運(yùn)行結(jié)果:
這是第一次保存Cookie
本次訪問(wèn)時(shí)間:16-07-16 08:26:25
第二次運(yùn)行結(jié)果:
上次訪問(wèn)時(shí)間為:16-07-16 08:26:25
本次訪問(wèn)時(shí)間:16-07-16 08:27:25
上述代碼,先通過(guò)isset()函數(shù)檢測(cè)Cookie文件是否存在,不存在通過(guò)setcookie()函數(shù)創(chuàng)建一個(gè)Cookie文件,如果存在設(shè)置Cookie的失效時(shí)間為60秒。
刪除Cookie
當(dāng)Cookie被創(chuàng)建后,如果沒(méi)有設(shè)置它的失效時(shí)間,其Cookie文件會(huì)在關(guān)閉瀏覽器時(shí)被自動(dòng)刪除。如果要在關(guān)閉瀏覽器之前刪除Cookie文件,方法有兩種:一種是使用setcookie()函數(shù)刪除,另一種是在瀏覽器中手動(dòng)刪除Cookie。下面分別進(jìn)行介紹。
1.使用setcookie()函數(shù)刪除Cookie
刪除Cookie和創(chuàng)建Cookie的方式基本類似,刪除Cookie也使用setcookie()函數(shù)。刪除Cookie只需要將setcookie()函數(shù)中的第二個(gè)參數(shù)設(shè)置為空值,將第3個(gè)參數(shù)Cookie的過(guò)期時(shí)間設(shè)置為小于系統(tǒng)的當(dāng)前時(shí)間即可。
例如,將Cookie的過(guò)期時(shí)間設(shè)置為當(dāng)前時(shí)間減1秒,代碼如下:
setcookie("name", "", time()-1);
在上面的代碼中,time()函數(shù)返回以秒表示的當(dāng)前時(shí)間戳,把過(guò)期時(shí)間減1秒就會(huì)得到過(guò)去的時(shí)間,從而刪除Cookie。
2.在瀏覽器中手動(dòng)刪除Cookie
在使用Cookie時(shí),Cookie自動(dòng)生成一個(gè)文本文件存儲(chǔ)在IE瀏覽器的Cookies臨時(shí)文件夾中。在瀏覽器中刪除Cookie文件是非常便捷的方法。
Cookie的生命周期
如果Cookie不設(shè)定時(shí)間,就表示它的生命周期為瀏覽器會(huì)話的期間,只要關(guān)閉IE瀏覽器,Cookie就會(huì)自動(dòng)消失。這種Cookie被稱為會(huì)話Cookie,一般不保存在硬盤上,而是保存在內(nèi)存中。
如果設(shè)置了過(guò)期時(shí)間,那么瀏覽器會(huì)把Cookie保存到硬盤中,再次打開IE瀏覽器時(shí)會(huì)依然有效,直到它的有效期超時(shí)。
雖然Cookie可以長(zhǎng)期保存在客戶端瀏覽器中,但也不是一成不變的。因?yàn)闉g覽器最多允許存儲(chǔ)300個(gè)Cookie文件,而且每個(gè)Cookie文件支持最大容量為4KB;每個(gè)域名最多支持20個(gè)Cookie,如果達(dá)到限制時(shí),瀏覽器會(huì)自動(dòng)地隨機(jī)刪除Cookies。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解cookie驗(yàn)證的php應(yīng)用的一種SSO解決辦法
- PHP與JavaScript針對(duì)Cookie的讀寫、交互操作方法詳解
- PHP利用Cookie設(shè)置用戶30分鐘未操作自動(dòng)退出功能
- PHP中Cookie的使用詳解(簡(jiǎn)單易懂)
- php及codeigniter使用session-cookie的方法(詳解)
- PHP如何讀取由JavaScript設(shè)置的Cookie
- PHP設(shè)置Cookie的HTTPONLY屬性方法
- php cookie用戶登錄的詳解及實(shí)例代碼
- php頁(yè)面跳轉(zhuǎn)session cookie丟失導(dǎo)致不能登錄等問(wèn)題的解決方法
- php cookie 詳解使用實(shí)例
- PHP中cookie知識(shí)點(diǎn)學(xué)習(xí)
相關(guān)文章
PHP使用ODBC連接數(shù)據(jù)庫(kù)的方法
這篇文章主要介紹了PHP使用ODBC連接數(shù)據(jù)庫(kù)的方法,涉及php使用ODBC操作數(shù)據(jù)庫(kù)的基本技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07如何使用PHP對(duì)象POPO來(lái)優(yōu)化你的代碼
如果您熟悉Java,可能您已經(jīng)知道POJO(普通Java類). 因?yàn)镻OJO這個(gè)詞最早是由Martin Fowler、Rebecca Parsons 和 Josh MacKenzie 于 2000 年在 Java 編程語(yǔ)言上創(chuàng)造的。 POJO 使我們更容易理解類對(duì)象中的數(shù)據(jù)結(jié)構(gòu)類型。本文將詳細(xì)介紹如何使用PHP對(duì)象POPO來(lái)優(yōu)化你的代碼。2021-05-05PHP程序61條面向?qū)ο蠓治鲈O(shè)計(jì)的經(jīng)驗(yàn)小結(jié)
你不必嚴(yán)格遵守這些原則,違背它們也不會(huì)被處以宗教刑罰。但你應(yīng)當(dāng)把這些原則看成警鈴,若違背了其中的一條,那么警鈴就會(huì)響起 。 ----- Arthur J.Riel2008-11-11Referer原理與圖片防盜鏈實(shí)現(xiàn)方法詳解
這篇文章主要介紹了Referer原理與圖片防盜鏈實(shí)現(xiàn)方法,結(jié)合實(shí)例形式詳細(xì)分析了Referer頭信息原理與圖片防盜鏈判定、實(shí)現(xiàn)方法,并附帶一個(gè)Http請(qǐng)求封裝類,需要的朋友可以參考下2019-07-07