PHP 如何清除COOKIE? PHP无法删除COOKIE?设置COOKIE有效期

PHP 透明地支持 HTTP cookie,  cookie是一种在远程浏览器端存储数据并以此来跟踪和识别用户的机制。可以用
setcookie() 或 setrawcookie()函数来设置cookie, cookie是HTTP标头的一部分,因此 setcookie()函数必须在
其他信息被输出到浏览器前调用,这和对header()函数的限制类似。
setcookie();


删除cookie的方法是把这个cookie的有效期设置为当前时间以前
setcookie('test', 'true', time() + 300); // 创建 cookie
//setcookie('test',time() - 3600 );  // 清除建立的 cookie
//setcookie('test'); //只是将 $_COOKIE['test'] 的值清空
如果直接setcookie('test', '');
echo '
';
print_r($_COOKIE); //attay();
会发现$_COOKIE数组是空的,而非仅仅$_COOKIE['test'] 为空,于是winsock抓包,观察返回的
http 头,竟然是:  set-cookie:test=deleted; expires=Mon, 29-May-2014 10:22:15 GMT


php  cookie 无法删除/清除过期?PHP <wbr>如何清除COOKIE? <wbr>PHP无法删除COOKIE?设置COOKIE有效期、COOKIE过期
登陆:
setcookie('username', 'zhangsan', time()+1000, "/php100");
退出:
setcookie('username', '', time()-3600);
发现做退出时 在IE下没问题,但是在Firefox中测试,登陆正常,无法退出,查看IE、Firefox中cookie记录的区别,经过测试
才发现原来没有指定 setcookie()的第四个参数(合法路径参数),所以导致登陆和退出时所设置cookie的路径不同(Firefox比较严格,导致又重新建了各变量)


发现做退出时 在IE下没问题,但是在Firefox中测试,登陆正常,无法退出,查看IE、Firefox中cookie记录的区别,经过测试
才发现原来没有指定 setcookie()的第四个参数(合法路径参数),所以导致登陆和退出时所设置cookie的路径不同(Firefox比较严格,导致又重新建了各变量)
PHP <wbr>如何清除COOKIE? <wbr>PHP无法删除COOKIE?设置COOKIE有效期、COOKIE过期


例:
$value = 'something';
setcookie('TestCookie', $value, time() + 3600);
setcookie('mytest', $value, time() + 3600, "~rasmus", ".maoge.com", 1);


if (isset($_COOKIE['TestCookie']))
{
echo 'TestCookie :' . $_COOKIE['TestCookie'];
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值