php中cookie实现二级域名可访问操作实例

cookie在一些应用中很常用,我有一个多级域名要可以同时访问主域名绑定的cookie,下面我来给大家具体介绍在php中利用setcookie实现二级域名可以成功访问主域名cookie值的方法.

有时候两个域名可能在不同的服务器上,但是我们依然希望二级域名能够顺利访问主域名的cookie,主域名可以顺利访问二级域名的cookie,比 如bbs.phpfensi.com 希望能访问 www.phpfensi.com 和 blog.phpfensi.com 的 cookie

下面介绍3种你可能常听到的全局cookie设置方式.

第一种实例代码如下:

setcookie("phpfensi",$s,time()+3600*12,'/','*.phpfensi.com');

*号无法成功设置一个cookie

第二种实例代码如下:

setcookie("phpfensi",$s,time()+3600*12,'/','.phpfensi.com');

成功设置一个全局cookie ss.phpfensi.com下也能正确读取

第三种实例代码如下:

setcookie("hzhuti",$s,time()+3600*12,'/','hzhuti.com');

成功设置一个全局cookie ss.phpfensi.com下也能正确读取

这种方式的理解是仅仅phpfensi.com能够读取,在FireFox下测试成功,IE下测试成功,代码如下:

setcookie("phpfensi",$s,time()+3600*12,'/','ss.phpfensi.com');

设置一个仅仅在ss.phpfensi.com域名下可以正确读取的cookie,网络上标准的说法为.phpfensi.com这样,也有*的说 法(该说法完全错误).下面推荐一个不错的php cookie操作的类,可以设置cookie、获取cookie、删除cookie,代码如下:

  1. <?php  

  2. /** 

  3. * php cookie类 

  4. * class:PHP_COOKIE 

  5. */ 

  6. class PHP_COOKIE  

  7. {  

  8.   var $_name  = "";  

  9.   var $_val   = array();  

  10.   var $_expires;  

  11.   var $_dir   = '/';// all dirs  

  12.   var $_site  = ''; 

  13.   function PHP_COOKIE($cname, $cexpires="", $cdir="/", $csite="")  

  14.   {  

  15. $this->_name=$cname; 

  16. if($cexpires){  

  17.   $this->_expires=$cexpires;  

  18. }  

  19. else{  

  20.   $this->_expires=time() + 60*60*24*30*12; // ~12 months  

  21. $this->_dir=$cdir;  

  22. $this->_site=$csite;  

  23. $this->_val=array();  

  24. $this->extract();  

  25.   } 

  26.   function extract($cname="")  

  27.   {  

  28. if(!isset($_COOKIE)){  

  29.   global $_COOKIE;  

  30.   $_COOKIE=$GLOBALS["HTTP_COOKIE_VARS"];  

  31. if(emptyempty($cname) && isset($this)){  

  32.   $cname=$this->_name;  

  33. }  

  34.  

  35. if(!emptyempty($_COOKIE[$cname])){ 

  36.   if(get_magic_quotes_gpc()){  

  37. $_COOKIE[$cname]=stripslashes($_COOKIE[$cname]);  

  38.   }  

  39.   $arr=unserialize($_COOKIE[$cname]); 

  40.   if($arr!==false && is_array($arr)){ 

  41. foreach($arr as $var => $val){ 

  42.   $_COOKIE[$var]=$val; 

  43.   if(isset($GLOBALS["PHP_SELF"])){  

  44.   $GLOBALS[$var]=$val;  

  45.   }  

  46. }  

  47.   } 

  48.   if(isset($this)) $this->_val=$arr; 

  49. }  

  50. // 在全局范围内移除cookie  

  51. unset($_COOKIE[$cname]);  

  52. unset($GLOBALS[$cname]);  

  53. function put($var, $value)  

  54. {  

  55. $_COOKIE[$var]=$value;  

  56. $this->_val["$var"]=$value; 

  57. if(isset($GLOBALS["PHP_SELF"])){  

  58.   $GLOBALS[$var]=$value;  

  59. if(emptyempty($value)){  

  60.   unset($this->_val[$var]);  

  61.   } 

  62.   function clear()  

  63.   {  

  64. $this->_val=array();  

  65.   } 

  66.   function set()  

  67.   {  

  68. if(emptyempty($this->_val)){  

  69.   $cookie_val="";  

  70. }   

  71. else {  

  72.   $cookie_val=serialize($this->_val);  

  73. }  

  74.  

  75. if(strlen($cookie_val)>4*1024){  

  76.   trigger_error("The cookie $this->_name exceeds the specification for the maximum cookie size.  Some data may be lost", E_USER_WARNING);  

  77. }  

  78. setcookie("$this->_name", $cookie_val, $this->_expires, $this->_dir, $this->_site);  

  79.   }  

  80. }  

  81. ?>


你可能感兴趣的:(php中cookie实现二级域名可访问操作实例)