1、設置Cookie
PHP用SetCookie函數來設置Cookie。必須注意的一點是:Cookie是HTTP協議頭的一部分,用於浏覽器和服務器之間傳遞信息,所以必須在任何屬於HTML文件本身的內容輸出之前調用Cookie函數。
SetCookie函數定義了一個Cookie,並且把它附加在HTTP頭的後面,SetCookie函數的原型如下:
int SetCookie(string name, string value, int expire, string path, string domain, int secure);
除 了name之外所有的參數都是可選的。value,path,domain三個參數可以用空字符串代換,表示沒有設置;expire 和 secure兩個參數是數值型的,可以用0表示。expire參數是一個標准的Unix時間標記,可以用time()或mktime()函數取得,以秒為 單位。secure參數表示這個Cookie是否通過加密的HTTPS協議在網絡上傳輸。
當前設置的Cookie不是立即生效的,而是要等到下一個頁面時才能看到.這是由於在設置的這個頁面裡Cookie由服務器傳遞給客戶浏覽器,在下一個頁面浏覽器才能把Cookie從客戶的機器裡取出傳回服務器的原因。
在同一個頁面設置Cookie,實際是從後往前,所以如果要在插入一個新的Cookie之前刪掉一個,你必須先寫插入的語句,再寫刪除的語句,否則可能會出現不希望的結果。
來看幾個例子:
如何創建 cookie?
setcookie() 函數用於設置 cookie。
注釋:setcookie() 函數必須位於 <html> 標簽之前。
語法
setcookie(name, value, expire, path, domain);
簡單的:
代碼如下 復制代碼SetCookie(“MyCookie”, “Value of MyCookie”);
帶失效時間的:
SetCookie(“WithExpire”, “Expire in 1 hour”, time()+3600);//3600秒=1小時
什麼都有的:
SetCookie(“FullCookie”, “Full cookie value”, time()+3600, “/forum”, “.phpuser.com”, 1);
這裡還有一點要說明 的,比如你的站點有幾個不同的目錄,那麼如果只用不帶路徑的Cookie的話,在一個目錄下的頁面裡設的Cookie在另一 個目錄的頁面裡是看不到的,也就是說,Cookie是面向路徑的。實際上,即使沒有指定路徑,WEB服務器會自動傳遞當前的路徑給浏覽器的,指定路徑會強 制服務器使用設置的路徑。解決這個問題的辦法是在調用SetCookie時加上路徑和域名,域名的格式可以是“www.phpuser.com”,也可是 “.phpuser.com”。
SetCookie 函數裡表示value的部分,在傳遞時會自動被encode,也就是說,如果 value的值是“test value”在傳遞時就變成了“test%20value”,跟URL的方法一樣。當然,對於程序來說這是透明的,因為在PHP接收Cookie的值時會 自動將其decode。
如果要設置同名的多個Cookie,要用數組,方法是:
代碼如下 復制代碼SetCookie(“CookieArray[]“, “Value 1″);
SetCookie(“CookieArray[]“, “Value 2″);
或
SetCookie(“CookieArray[0]“, “Value 1″);
SetCookie(“CookieArray[1]“, “Value 2″);
2、接收和處理Cookie
PHP對Cookie的接收和處理的支持非常好,是完全自動的,跟FORM變量的原則一樣,特別簡單。
比如設置一個名為 MyCookier的Cookie,PHP會自動從WEB服務器接收的HTTP頭裡把它分析出來,並形成一個與普通變量一樣的變量,名為$ myCookie,這個變量的值就是Cookie的值。數組同樣適用。另外一個辦法是引用PHP的全局變量$HTTP_COOKIE_VARS數組。
分別舉例如下:(假設這些都在以前的頁面裡設置過了,並且仍然有效)
代碼如下 復制代碼echo $MyCookie;
echo $CookieArray[0];
echo count($CookieArray
如何取回 Cookie 的值?
PHP 的 $_COOKIE 變量用於取回 cookie 的值。
在下面的例子中,我們取回了名為 "user" 的 cookie 的值,並把它顯示在了頁面上:
代碼如下 復制代碼<?php
// Print a cookie
echo $_COOKIE["user"];
// A way to view all cookies
print_r($_COOKIE);
?>
在下面的例子中,我們使用 isset() 函數來確認是否已設置了 cookie:
代碼如下 復制代碼<html>
<body>
<?php
if (isset($_COOKIE["user"]))
echo "Welcome " . $_COOKIE["user"] . "!<br />";
else
echo "Welcome guest!<br />";
?>
</body>
</html>
如何刪除 cookie?
當刪除 cookie 時,您應當使過期日期變更為過去的時間點。
刪除的例子:
代碼如下 復制代碼<?php
// set the expiration date to one hour ago
setcookie("user", "", time()-3600);
?>
例子
php cookie來設置用戶登陸的時間與過期時間代碼哦
代碼如下 復制代碼function loginCookie($uid,$name,$group,$ip,$time)
{
global $site_domain,$login_key;
$domain = (substr($site_domain,0,4) == "www.") ? substr($site_domain,3) : ".".$site_domain;
$secure = Xxtea::encrypt($uid."|".$name."|".$group."|".$ip,$login_key);
setcookie("userId",$uid,$time+86400,"/",$domain);
setcookie("userName",$name,$time+86400,"/",$domain);
setcookie("userGroup",$group,$time+86400,"/",$domain);
setcookie("userSecure",$secure,$time+86400,"/",$domain);
}
更多詳細內容請查看:http://www.111cn.net/phper/18/1b5df18d38cfea1a63282c367f6cdf63.htm