1、設定Cookie
1. PHP 的COOKIE
cookie 是一種在遠程瀏覽器端儲存資料並以此來跟蹤和識別使用者的機制。
PHP 在http 協議的頭資訊裡發送cookie,因此 setcookie() 函數必須在其它資訊被輸出到瀏覽器
前調用,這和對 header() 函數的限制類似。
1.1 設定cookie:
可以用 setcookie()或 setrawcookie()函數來設定 cookie。也可以通過向用戶端直接發送http 頭來
設定。
1.1.1 使用 setcookie()函數設定cookie:
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure [, bool
httponly]]]]]] )
name: cookie 變數名
value: cookie 變數的值
expire: 有效期間結束的時間
path: 有效目錄
domain: 有效網域名稱,頂級域唯一
secure: 如果值為 1,則cookie 只能在https 串連上有效,如果為預設值 0,則http 和 https 都可
以。
來看幾個例子:
簡單的:
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); |
我們需要用到隊列。
| 代碼如下 |
複製代碼 |
class QueueSvc {/*{{{*/ private $length; // 隊列的長度 private $server_arr; public function __construct($length,$server_arr) { $this->length = $length; $this->server_arr = $server_arr; } public function getServerArr() { return $this->server_arr; } public function set($server_name) { self::push($server_name); } private function push($server_name) { //有重複的記錄,把重複的刪掉 if(self::isServerExist($server_name)){ self::removeRepeat($server_name); }else{ if(self::isFull()){ //如果已經滿了,要把隊列最後一個記錄刪掉 array_pop($this->server_arr); } } //如果隊列為空白,先置為空白數組 if(empty($this->server_arr)) $this->server_arr = array(); //向隊列頭添加資料 array_unshift($this->server_arr,$server_name); } private function isFull() { if(is_array($this->server_arr) && (count($this->server_arr) >= $this->length)) return true; return false; } private function isServerExist($server_name) { if(is_array($this->server_arr) && in_array($server_name,$this->server_arr)) return true; return false; } private function removeRepeat($server_name) { if(is_array($this->server_arr) && in_array($server_name,$this->server_arr)) { foreach($this->server_arr as $key=>$value) { if($server_name == $value) { $this->array_remove($this->server_arr,$key); } } } } private function array_remove(&$arr, $offset) { array_splice ( $arr, $offset, 1 ); } }/*}}}*/require_once('queue_svc.php'); class CookieSvc {/*{{{*/ const COOKIE_KEY = "GAME_SERVER"; const SEPARATE = "|"; const COOKIE_LENGTH = "2"; public function getCookieArr() {/*{{{*/ $server_str = $_COOKIE[self::COOKIE_KEY]; $server_str = $_COOKIE['GAME_SERVER']; if($server_str == ''){ $result = array(); }else{ $result = explode(self::SEPARATE,$server_str); } return $result; }/*}}}*/ public function set($cookie_id) {/*{{{*/ $server_arr = self::getCookieArr(); if($cookie_id != false) { $que = new QueueSvc(self::COOKIE_LENGTH,$server_arr); $que->set($cookie_id); $server_new = $que->getServerArr(); if(is_array($server_new)) { $cookie_str = implode(self::SEPARATE,$server_new); setcookie(self::COOKIE_KEY,$cookie_str,time()+3600,'/'); } } }/*}}}*/ }/*}}}*/ |
不多解釋了,這個別人用的不多,昨天因為需要寫的,留一下吧,也許以後還用得到。。
調用的代碼很簡單:
| 代碼如下 |
複製代碼 |
require_once("queue_svc.php"); require_once("cookie_svc.php"); $cookie_id = '4'; CookieSvc::set($cookie_id); |
這樣就可以了。呼。。大家可以每次把$cookie_id換做不同的值,來檢驗此操作。
檢驗的代碼可以用如下代碼:
| 代碼如下 |
複製代碼 |
| var_dump($_COOKIE); |
常見問題解決:
1) 用 setcookie()時有錯誤提示,可能是因為調用setcookie()前面有輸出或空格。也可能你的文
檔是從其他字元集轉換過來,文檔後面可能帶有 BOM 簽名(就是在檔案內容添加一些隱藏
的BOM 字元)。解決的辦法就是使你的文檔不出現這種情況。還有通過使用ob_start()函數
也能處理一點。
2) $_COOKIE 受magic_quotes_gpc 影響,可能自動轉義。
3) 使用的時候,有必要測試使用者是否支援cookie