用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

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

时间:2015-01-23  来源:西部数据  作者:西部数据

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. ?>
来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门