會(huì)話技術(shù)要實(shí)現(xiàn)的功能是:在同一個(gè)瀏覽器與服務(wù)器的多次請(qǐng)求間,將數(shù)據(jù)持久化存儲(chǔ)的技術(shù)蛛砰。會(huì)話技術(shù)包括兩種:1.cookie 2.session
典型例子:在使用同一個(gè)瀏覽器進(jìn)行登錄某個(gè)網(wǎng)站時(shí)素挽,往往第二次再進(jìn)入網(wǎng)站主頁(yè)時(shí),無(wú)需登錄就自動(dòng)跳轉(zhuǎn)到了登錄后的頁(yè)面。
基本原理
cookie允許服務(wù)器端腳本在瀏覽器端存儲(chǔ)數(shù)據(jù)献联。且通常在瀏覽器端存在茴恰,它允許服務(wù)器向?yàn)g覽器發(fā)送指令颠焦,用來(lái)管理存儲(chǔ)在瀏覽器端的cookie數(shù)據(jù)。瀏覽器如果存儲(chǔ)了某臺(tái)服務(wù)器所設(shè)置的cookie數(shù)據(jù)往枣,瀏覽器再向服務(wù)器請(qǐng)求時(shí)伐庭,會(huì)攜帶存儲(chǔ)的cookie數(shù)據(jù)到服務(wù)器端。
Cookie基本操作
增刪改
Setcookie(KEY, VALUE)
cookie數(shù)據(jù)在php中以鍵值對(duì)存在婉商,KEY代表鍵似忧,VALUE代表值。設(shè)置時(shí)當(dāng)KEY已經(jīng)存在時(shí)更新丈秩,不存在添加盯捌。VALUE置空或者不填寫時(shí)為刪除。
//增蘑秽,改
setCokkie('class_name','PHP');
//刪除
setCookie('class_name','');
setCookie('class_name');
查詢
獲取瀏覽器在請(qǐng)求時(shí)攜帶的COOKIE數(shù)據(jù)饺著,使用超全局?jǐn)?shù)組變量箫攀,$_COOKIE 完成對(duì)cookie數(shù)據(jù)獲取。PHP核心幼衰,在初始化階段靴跛,會(huì)將所有請(qǐng)求的cookie數(shù)據(jù),整理到$_COOKIE變量中渡嚣,供PHP腳本所使用梢睛!
$_COOKIE['class_name'];
其中 每個(gè)$_COOKIE中的元素,對(duì)應(yīng)一個(gè)cookie變量识椰,元素的鍵就是cookie的KEY绝葡,元素的值,就是cookie的Value腹鹉。
有效期
一般默認(rèn)情況下設(shè)置的Cookie為臨時(shí)Cookie藏畅,在會(huì)話周期結(jié)束后自動(dòng)刪除(瀏覽器關(guān)閉),但我們可以通過(guò)PHP來(lái)設(shè)置瀏覽器中存儲(chǔ)Cookie的有效期
setCookie('expire_cookie','expire',time()+60);
SetCookie()的第三個(gè)參數(shù)可以對(duì)有效期進(jìn)行設(shè)置功咒,有效期用時(shí)間戳表示愉阎。
注意:
- cookie是否失效由瀏覽器判定。
- 將第三個(gè)參數(shù)設(shè)置為0表示該cookie為臨時(shí)cookie力奋。
- 刪除cookie的標(biāo)準(zhǔn)做法是將第三個(gè)參數(shù)設(shè)置為time()-1,即過(guò)去的時(shí)間榜旦,例如
setCookie(‘KEY’,‘’, time()-1)
,setCookie(‘KEY’,‘’)也可以刪除但不推薦刊侯。
有效路徑
一般默認(rèn)情況下Cookie只在當(dāng)前路徑和當(dāng)前路徑后的分支路徑有效章办。我們可以通過(guò)設(shè)置setCookie的第四個(gè)參數(shù)進(jìn)行設(shè)置。
setCookie('path_anywhere','whereami',0,'/');
通常將第四個(gè)參數(shù)設(shè)置為/滨彻,表示站點(diǎn)根目錄有效藕届,即整站有效。
注意:
- 這里代表的路徑是指URL請(qǐng)求的路徑亭饵,而不是本地所存儲(chǔ)的文件路徑休偶。
-
不同路徑下,KEY值相同的Cookie可以同時(shí)存儲(chǔ)于瀏覽器端
- 當(dāng)有相同KEY的Cookie時(shí)辜羊,會(huì)先查找當(dāng)前目錄內(nèi)有效的cookie,再向上查找踏兜,將所有有效的Cookie都帶到瀏覽器,瀏覽器在形成$_COOKIE時(shí)八秃,會(huì)出現(xiàn)重寫寫過(guò)碱妆,把先出現(xiàn)的保存。
- 有效路徑的判斷也在瀏覽器端完成昔驱。服務(wù)器設(shè)置有效路徑并響應(yīng)瀏覽器時(shí)會(huì)將路徑傳送給瀏覽器疹尾。
有效域名
默認(rèn)情況下,Cookie僅僅在當(dāng)前域名下有效,可以通過(guò)設(shè)置setCookie()中的第五個(gè)參數(shù)纳本,來(lái)擴(kuò)展到某個(gè)一級(jí)域名下的所有子域有效窍蓝。
www.k1y1.com為一級(jí)域名,shop.k1y1.com為二級(jí)域名繁成。
setCookie('domain_name','in_test_kang',0,'/','kang.com');
安全傳輸
所謂安全傳輸是指在https ://下吓笙,向服務(wù)器進(jìn)行數(shù)據(jù)請(qǐng)求。默認(rèn)情況下巾腕,不論瀏覽器發(fā)出的是http還是https都會(huì)將有效的cookie攜帶到服務(wù)器面睛,將setCookie()的第六個(gè)參數(shù)這只為true,表示僅在https請(qǐng)求下攜帶cookie數(shù)據(jù)給服務(wù)器。
setCookie('not_secure','php',0,'','',false);//不開(kāi)啟僅安全連接傳輸
setCookie('do_secure','php',0,'','',false);//開(kāi)啟僅安全連接傳輸
HTTPONLY
默認(rèn)情況下尊搬,瀏覽器存儲(chǔ)的cookie是可以被其他腳本所處理的侮穿。通過(guò)設(shè)置第7個(gè)參數(shù),可以禁止其他腳本處理PHP設(shè)置的cookie信息毁嗦。
setCookie('do_httponly','php',0,'','',false,true);//開(kāi)啟HTTPONLY
setCookie('not_httponly','php',0,'','',false,false);//關(guān)閉HTTPONLY
關(guān)于Cookie的介紹就到這里,這只是為繼續(xù)介紹Session技術(shù)做一個(gè)小鋪墊回铛。隨后為繼續(xù)介紹PHP中Session的一些操作狗准。