php清除cookie的方法:首先通过setcookie创建cookie;然后使用“setcookie('test',time() - 3600 );”方法清除建立的cookie即可。
推荐:《PHP视频教程》
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
登陆:
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比较严格,导致又重新建了各变量)
例:
$value = 'something'; setcookie('TestCookie', $value, time() + 3600); setcookie('mytest', $value, time() + 3600, "~rasmus", ".maoge.com", 1); if (isset($_COOKIE['TestCookie'])) { echo 'TestCookie :' . $_COOKIE['TestCookie']; }
以上是php 如何清除 cookie的详细内容。更多信息请关注PHP中文网其他相关文章!