首頁 >後端開發 >php教程 >學習PHP Cookie處理函數_php實例

學習PHP Cookie處理函數_php實例

WBOY
WBOY原創
2016-08-17 13:02:30931瀏覽

我們先看看cookie是什麼東東? 

cookie是伺服器留在客戶端的用於識別使用者或儲存一些資料的小檔案(注意,session儲存在伺服器端,這是兩者的區別之一)。我們平時登入某個入口網站時,會有選項“是否儲存登入”或“下次自動登入”,當我們勾選了之後,伺服器就會在我們的瀏覽器建立cookie檔案來儲存我們的資訊。每當電腦透過瀏覽器請求頁面時,它會同時發送cookie。透過PHP,可以建立並取回cookie的值。 cookie在web中是很重要的角色,早在網景瀏覽器的時候就產生了cookie。 cookie經常被用於使用者驗證系統。 

1.建立cookie
函數setcookie()可以在PHP中產生cookie。由於cookie是HTTP頭標部分的內容,因此必須在輸出任何資料之前呼叫setcookie(),這個限制和header()類似,定義:
bool setcookie( string name[,string value][,int expire][,string path][,string domain][,bool secure][,bool httponly])  

好多參數啊! Σ(⊙▽⊙"a 不急,讓我們來看看各個參數的功能: 
name  :  必選,表示cookie的名字。 
value  :  可選,表示cookie值,儲存在客戶端,當為空時,表示撤銷客戶端中該cookie的資料(這樣可以刪除cookie)。 
expire  :  可選,表示cookie的有效截止時間,也就是過期時間,如果沒有指定或指定為0,那麼通常是在關閉瀏覽器時失效。 
path  :  可選,cookie有效路徑。 
domain  :  可選,cookie有效網域。 
secure  :  表示在HTTPS的安全傳輸時才有效。 
實例(建立名字為test,值為China的cookie):

 <&#63;php
 setcookie("test",China");
 &#63;> 

 使用setcookie()給的值只能是數字或字串,不能是其他的複雜結構。

2.取得cookie
建立cookie後,就可以使用預先定義變數$_COOKIE來取得cookie。不過,只能在其他頁面取得cookie,因為在php中,被設定的cookie不會在本頁面生效,除非該頁面被刷新。
實例:

 <&#63;php
 setcookie("test","China");
 echo "cookie is ".$_COOKIE["test"];
 &#63;> 

 這裡之所以要刷新頁面,是因為cookie的值不會在呼叫setcookie()之後立即儲存在C OOKIE變數中,而是隨著http請求被傳送到伺服器,這時候cookie的值才會出現在COOKIE變數中,而是隨著http請求被傳送至伺服器,這時候cookie的值才會出現在_COOKIE中。 (博客園對於dollar符不支持麼。。。啊啊啊) 

3.cookie的有效期限
cookie有生命週期,也就是cookie存在的有效時間。可以設定第三個參數來設定有效時間。
實例(設定cookie有效時間的幾種方式): 

setcookie("cookie_one","A",time()+60*60);    //cookie在一小时后失效
setcookie("cookie_two","B",time()+60*60*24);  //cookie在一天后失效
setcookie("cookie_three","C",mktime(23,53,19,10,09,2020));  //cookie在2020年10月9日23时53分19秒失效
setcookie("cookie_four","D");   //关闭浏览器后cookie失效  

4.cookie的有效路徑
cookie中的路徑用來控制設定的cookie在哪個路徑下有效,預設為'/',在所有路徑下都有效,也就是在整個伺服器網域下都有效,當設定了其他路徑之後,則只在設定的路徑以及子路徑下有效,例如:
setcookie('test', time(), 0, '/path'); 
上面的設定會讓test在/path以及子路徑/path/abc下都有效,但是在根目錄下就讀取不到test的cookie值。 

一般情況下,大多是使用所有路徑的,只有在極少數有特殊需求的時候,會設定路徑,這種情況下只在指定的路徑中才會傳遞cookie值,可以節省資料的傳輸,增強安全性以及提高性能。

5.刪除cookie
刪除cookie比較簡單,也是透過setcookie()來實現的(不要用unset()!!!)下面的程式碼就是個簡單範例:setcookie("test",""); 
透過將第二個參數設為空來達到刪除cookie的目的。如果設定cookie時,為cookie提供了特定的值,那麼在刪除cookie時,仍然需要提供這些參數,以便PHP可以正確地刪除cookie。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn