萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> php編程 >> php cookie設置 刪除 登錄詳解

php cookie設置 刪除 登錄詳解

cookie是所有程序開發中會有的一種東西,下面我來介紹cookie設置(SetCookie) 刪除($_COOKIE) 登錄用法。

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

copyright © 萬盛學電腦網 all rights reserved