php cookie操作之隊列操作類

來源:互聯網
上載者:User

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.