首先編寫以下簡單的代碼:
複製代碼 代碼如下:
<?php
setcookie('a','value');
print $_COOKIE['a'];
第一次訪問時,報錯:
報錯的原因是$_COOKIE['a']的值不存在。第二次訪問:
問:為什麼第一次訪問的時候,會沒有cookie呢??我不是先設定,再擷取嗎??
答:使用firefox的firebug查看”網路“:
用戶端:
可以看到,瀏覽器(用戶端)向伺服器發出一次請求,發出請求的時候,在要求標頭資訊中帶上了各種參數,告訴伺服器,我要接收什麼樣的文本(Accept)、什麼編碼格式(Accept-Encoding)、什麼語言(Accept-Language)等等,當然,還把Cookie也傳到了伺服器(Cookie)。
伺服器端:
第一步:setcookie('a','value')
因為cookie是設定在用戶端的,setcookie函數自己並不能設定cookie,它只能通過頭資訊的方式告訴瀏覽器說:兄弟,我要設定一個cookie,鍵為a,值為value,你在你那裡幫我設定一下。你也可以理解為:”來,朕今天高興,賞你一個小甜餅“。
第二步:$_COOKIE['a']$_COOKIE['a']
很簡單,執行的操作就是在瀏覽器帶過來的cookie字串中搜尋鍵為a的cookie,並返回它的值。
很明顯,這個”鍵為a“的cookie不可能找到,因為Client Access Server的時候,這個cookie壓根就不存在,而前面第一步設定cookie的頭資訊,也還沒有返回給用戶端(php要從上到下把語句執行完才會返回給用戶端)
第三步:伺服器返回資訊
其中,返回的頭資訊中帶有”Set-Cookie a=value“,瀏覽器收到這個頭資訊,把cookie存放到電腦的某個檔案中,對於不同瀏覽器cookie的存放位置貌似不同,這個不在本文的範圍。
重新整理瀏覽器,再次訪問伺服器的時候,同樣,也會把很多頭資訊帶給伺服器,只不過這次帶過去的cookie中,就多了一個a=value了。所心$_COOKIE['a']自然就能從cookie字串中找到這個鍵為a的cookie的值。