php中cookie实现二级域名可访问操作实例
cookie在一些应用中很常用,我有一个多级域名要可以同时访问主域名绑定的cookie,下面我来给大家具体介绍在php中利用setcookie实现二级域名可以成功访问主域名cookie值的方法.
有时候两个域名可能在不同的服务器上,但是我们依然希望二级域名能够顺利访问主域名的cookie,主域名可以顺利访问二级域名的cookie,比如bbs.phprm.com 希望能访问 www.phprm.com 和 blog.phprm.com 的 cookie
下面介绍3种你可能常听到的全局cookie设置方式.
第一种实例代码如下:
setcookie("phpfensi",$s,time()+3600*12,'/','*.phprm.com');
*号无法成功设置一个cookie
第二种实例代码如下:
setcookie("phpfensi",$s,time()+3600*12,'/','.phprm.com');
成功设置一个全局cookie ss.phprm.com下也能正确读取
第三种实例代码如下:
setcookie("phprm",$s,time()+3600*12,'/','phprm.com');
成功设置一个全局cookie ss.phprm.com下也能正确读取
这种方式的理解是仅仅phprm.com能够读取,在FireFox下测试成功,IE下测试成功,代码如下:
setcookie("phpfensi",$s,time()+3600*12,'/','ss.phprm.com');
设置一个仅仅在ss.phprm.com域名下可以正确读取的cookie,网络上标准的说法为.phprm.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 (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);
}
}
?>
文章链接:http://www.phprm.com/develop/fs1143.html
随便收藏,请保留本文地址!