先寫以下簡單的程式碼:
複製程式碼 程式碼如下:
<?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不可能找到,因為客戶端存取伺服器的時候,這個cookie壓根就不存在,而前面第一步設定cookie的頭訊息,也還沒有回傳給客戶端(php要從上到下把語句執行完才會回傳至客戶端)
第三步:伺服器回傳訊息
其中,傳回的頭訊息中帶有」Set-Cookie a=value“,瀏覽器收到這個頭信息,把cookie存放到電腦的某個文件中,對於不同瀏覽器cookie的存放位置貌似不同,這個不在本文的範圍。
刷新瀏覽器,再次訪問伺服器的時候,同樣,也會把很多頭資訊帶給伺服器,只不過這次帶過去的cookie中,就多了一個a=value了。 _COOKIE['a']自然就能從cookie字串中找到這個鍵為a的cookie的值。 #使用php cookie做的登入驗證實例程式碼
php Cookies 操作類別以上是PHP setcookie() 首次儲存不上值的詳細內容。更多資訊請關注PHP中文網其他相關文章!