cookie在一些應用中很常用,我有一個多級域名要可以同時訪問主域名綁定的cookie,下面我來給大家具體介紹在php中利用setcookie實現二級域名可以成功訪問主域名cookie值的方法。
有時候兩個域名可能在不同的服務器上,但是我們依然希望二級域名能夠順利訪問主域名的cookie,主域名可以順利訪問二級域名的cookie。比如bbs.hzhuti.com 希望能訪問www.hzhuti.com和blog.hzhuti.com的cookie
下面介紹3種你可能常聽到的全局cookie設置方式
setcookie("hzhuti",$s,time()+3600*12,'/','*.hzhuti.com');
*號無法成功設置一個cookie
代碼如下 復制代碼setcookie("hzhuti",$s,time()+3600*12,'/','.hzhuti.com');
成功設置一個全局cookie ss.hzhuti.com下也能正確讀取
代碼如下 復制代碼setcookie("hzhuti",$s,time()+3600*12,'/','hzhuti.com');
成功設置一個全局cookie ss.hzhuti.com下也能正確讀取
這種方式月小升的理解是僅僅hzhuti.com能夠讀取。月小升在FireFox下測試成功。IE下成功
代碼如下 復制代碼setcookie("hzhuti",$s,time()+3600*12,'/','ss.hzhuti.com');
設置一個僅僅在ss.hzhuti.com域名下可以正確讀取的cookie
網絡上標准的說法為.hzhuti.com這樣。
也有*的說法(該說法完全錯誤。。。)
下面推薦一個不錯的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(empty($cname) && isset($this)){
$cname=$this->_name;
}
if(!empty($_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(empty($value)){
unset($this->_val[$var]);
}
}
function clear()
{
$this->_val=array();
}
function set()
{
if(empty($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);
}
}
?>