当前位置:首页 > PHP教程 > php应用 > 列表

php中cookie实现二级域名可访问操作的方法

发布:smiling 来源: PHP粉丝网  添加日期:2021-04-25 14:03:53 浏览: 评论:0 

这篇文章主要介绍了php中cookie实现二级域名可访问操作的方法,对比了常用的setcookie函数用法,并给出了一个设置cookie的类文件来实现这一功能,是非常实用的技巧,需要的朋友可以参考下。

本文实例讲述了php中cookie实现二级域名可访问操作的方法。分享给大家供大家参考。具体方法如下:

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

有时候两个域名可能在不同的服务器上,但是我们依然希望二级域名能够顺利访问主域名的cookie,主域名可以顺利访问二级域名的cookie,比如sc.jb51.net 希望能访问 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("phpfensi",$s,time()+3600*12,'/','phpfensi.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. }  
  22. $this->_dir=$cdir;   
  23. $this->_site=$csite;   
  24. $this->_val=array();   
  25. $this->extract();   
  26.   }  
  27.   function extract($cname="")   
  28.   {   
  29. if(!isset($_COOKIE)){   
  30.   global $_COOKIE;   
  31.   $_COOKIE=$GLOBALS["HTTP_COOKIE_VARS"];   
  32. }  
  33. if(emptyempty($cname) && isset($this)){   
  34.   $cname=$this->_name;   
  35. }   
  36.  
  37. if(!emptyempty($_COOKIE[$cname])){  
  38.   if(get_magic_quotes_gpc()){   
  39. $_COOKIE[$cname]=stripslashes($_COOKIE[$cname]);   
  40.   }   
  41.   $arr=unserialize($_COOKIE[$cname]);  
  42.   if($arr!==false && is_array($arr)){  
  43. foreach($arr as $var => $val){  
  44.   $_COOKIE[$var]=$val;  
  45.   if(isset($GLOBALS["PHP_SELF"])){   
  46.   $GLOBALS[$var]=$val;   
  47.   }   
  48. }   
  49.   }  
  50.   if(isset($this)) $this->_val=$arr;  
  51. }   
  52. // 在全局范围内移除cookie   
  53. unset($_COOKIE[$cname]);   
  54. unset($GLOBALS[$cname]);   
  55. }  
  56. function put($var$value)   
  57. {   
  58. $_COOKIE[$var]=$value;   
  59. $this->_val["$var"]=$value;  
  60. if(isset($GLOBALS["PHP_SELF"])){   
  61.   $GLOBALS[$var]=$value;   
  62. }  
  63. if(emptyempty($value)){   
  64.   unset($this->_val[$var]);   
  65. }  
  66.   }  
  67.   function clear()   
  68.   {   
  69. $this->_val=array();   
  70.   }  
  71.   function set()   
  72.   {   
  73. if(emptyempty($this->_val)){   
  74.   $cookie_val="";   
  75. }    
  76. else {   
  77.   $cookie_val=serialize($this->_val);   
  78. }   
  79. //www.phpfensi.com 
  80. if(strlen($cookie_val)>4*1024){   
  81.   trigger_error("The cookie $this->_name exceeds the specification for the maximum cookie size.  Some data may be lost", E_USER_WARNING);   
  82. }   
  83. setcookie("$this->_name"$cookie_val$this->_expires, $this->_dir, $this->_site);   
  84.   }   
  85. }   
  86. ?> 

希望本文所述对大家的PHP程序设计有所帮助。

Tags: cookie php二级域名

分享到: