本文實例講述了php中cookie實現二級域名可訪問操作的方法。分享給大家供大家參考。具體方法如下:
cookie在一些應用中很常用,假設我有一個多級域名要求可以同時訪問主域名綁定的cookie,下面就來給大家具體介紹在php中利用setcookie實現二級域名可以成功訪問主域名cookie值的方法.
有時候兩個域名可能在不同的服務器上,但是我們依然希望二級域名能夠順利訪問主域名的cookie,主域名可以順利訪問二級域名的cookie,比如sc.jb51.net 希望能訪問 www.jb51.net 和 blog.jb51.net 的 cookie
下面介紹3種你可能常聽到的全局cookie設置方式.
第一種實例代碼如下:
setcookie("jb51",$s,time()+3600*12,'/','*.jb51.net');
*號無法成功設置一個cookie
第二種實例代碼如下:
setcookie("jb51",$s,time()+3600*12,'/','.jb51.net');
成功設置一個全局cookie,這樣在ss.jb51.net下也能正確讀取
第三種實例代碼如下:
setcookie("jb51",$s,time()+3600*12,'/','jb51.net');
成功設置一個全局cookie,在ss.jb51.net下也能正確讀取
這種方式的理解是僅僅jb51.net能夠讀取,在FireFox下測試成功,IE下測試成功,代碼如下:
setcookie("jb51",$s,time()+3600*12,'/','ss.jb51.net');
設置一個僅僅在ss.jb51.net域名下可以正確讀取的cookie,網絡上標准的說法為.jb51.net這樣,也有*的說法(該說法完全錯 誤).下面推薦一個不錯的php cookie操作的類,可以設置cookie、獲取cookie、刪除cookie,代碼如下:
<?php /** * php cookie類 * class:PHP_COOKIE */ class PHP_COOKIE { var $_name = ""; var $_val = array(); var $_expires; var $_dir = '/';// all dirs var $_site = ''; function PHP_COOKIE($cname, $cexpires="", $cdir="/", $csite="") { $this->_name=$cname; if($cexpires){ $this->_expires=$cexpires; } else{ $this->_expires=time() + 60*60*24*30*12; // ~12 months } $this->_dir=$cdir; $this->_site=$csite; $this->_val=array(); $this->extract(); } function extract($cname="") { if(!isset($_COOKIE)){ global $_COOKIE; $_COOKIE=$GLOBALS["HTTP_COOKIE_VARS"]; } if(emptyempty($cname) && isset($this)){ $cname=$this->_name; } if(!emptyempty($_COOKIE[$cname])){ if(get_magic_quotes_gpc()){ $_COOKIE[$cname]=stripslashes($_COOKIE[$cname]); } $arr=unserialize($_COOKIE[$cname]); if($arr!==false && is_array($arr)){ foreach($arr as $var => $val){ $_COOKIE[$var]=$val; if(isset($GLOBALS["PHP_SELF"])){ $GLOBALS[$var]=$val; } } } if(isset($this)) $this->_val=$arr; } // 在全局范圍內移除cookie unset($_COOKIE[$cname]); unset($GLOBALS[$cname]); } function put($var, $value) { $_COOKIE[$var]=$value; $this->_val["$var"]=$value; if(isset($GLOBALS["PHP_SELF"])){ $GLOBALS[$var]=$value; } if(emptyempty($value)){ unset($this->_val[$var]); } } function clear() { $this->_val=array(); } function set() { if(emptyempty($this->_val)){ $cookie_val=""; } else { $cookie_val=serialize($this->_val); } if(strlen($cookie_val)>4*1024){ trigger_error("The cookie $this->_name exceeds the specification for the maximum cookie size. Some data may be lost", E_USER_WARNING); } setcookie("$this->_name", $cookie_val, $this->_expires, $this->_dir, $this->_site); } } ?>