您好,欢迎访问一九零五行业门户网

php cookie如何清除

php cookie的清除方法:首先创建一个php示例文件;然后通过setcookie创建cookie;最后通过“setcookie('test','',time()-3600);”方法清除建立的cookie即可。
推荐:《php视频教程》
本教程操作环境:windows7系统、php5.6版,该方法适用于所有品牌电脑。
php清除cookie,php无法删除cookie?
设置cookie有效期、cookie过期
php手册中提到:
php 透明地支持 http cookie。cookie 是一种在远程浏览器端储存数据并以此来跟踪和识别用户的机制。可以用 setcookie() 或 setrawcookie() 函数来设置 cookie。cookie 是 http 标头的一部分,因此 setcookie() 函数必须在其它信息被输出到浏览器前调用,这和对 header() 函数的限制类似。
setcookie():bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
要删除 cookie 需要确保它的失效期是在过去,才能触发浏览器的删除机制。
删除一个cookie的方法就是把这个cookie的有效期设置为当前时间以前,这也是几乎所有php程序员都会这么做。
例如:
setcookie('test','true',time()+3600); //创建cookiesetcookie('test','',time()-3600); //清除建立的cookie
==================================================================================
如果直接setcookie("test", '');
print_r($_cookie);
结果是整个$_cookie数组都是空的,而非仅仅$_cookie['testcookie']为空.于是用winsock抓包,观察返回的http头,发现http头竟然是
set-cookie: testcookie=deleted; expires=mon, 18-jun-2007 02:42:33 gmt
这说明setcookie("testcookie", '');的的确确是将testcookie这个cookie直接删除.而关于这种情况在php手册中完全没有说明.
最后阅读php源码,终于发现真相(这就是开源的好处了,有什么不清楚的内幕直接查源码)
以下代码可以在php5.20的linux源码包中ext/standard/head.c第99行附近找到.
if (value && value_len == 0) {time_t t = time(null) - 31536001;dt = php_format_date("d, d-m-y h:i:s t", sizeof("d, d-m-y h:i:s t")-1, t, 0 tsrmls_cc);sprintf(cookie, "set-cookie: %s=deleted; expires=%s", name, dt);efree(dt);} else {sprintf(cookie, "set-cookie: %s=%s", name, value ? encoded_value : "");if (expires > 0) {strcat(cookie, "; expires=");dt = php_format_date("d, d-m-y h:i:s t", sizeof("d, d-m-y h:i:s t")-1, expires, 0 tsrmls_cc);strcat(cookie, dt);efree(dt);}}
源码中清清楚楚的显示,if (value && value_len == 0) ,当value_len为0

sprintf(cookie, "set-cookie: %s=deleted; expires=%s", name, dt);
会发送删除cookie的http头给浏览器.
最后我们可以得出结论,在php中使用
setcookie($cookiename, '');或者 setcookie($cookiename, null);
都会删除cookie,当然这些手册中并没有。
=====================================================================================
php cookie 无法删除/清除过期?
今天利用 cookie 做网站的用户登录,经过调试,用
setcookie("username", "username", time()+1000,"/php100/");
等储存用户的登录信息,然后利用
setcookie("username", "", time()-3600);
做 退出,在ie下测试没有任何问题。既然做网站,就要兼容尽可能多的浏览器,呵呵。于是在 firefox 中测试,登陆一切正常,当 推出时,遇到了麻烦。怎么也不会退出,用户总是在登录状态。于是查看了 ie、firefox 中cookie记录的区别,经过测试,才恍然大悟。
原来如果没有指定 setcookie() 的第四个参数(合法路径参数),默认会把当前目录作为合法路径,而我测试的路径为:http://127.0.0.1/php/rss2fla/data /log.php ,所以导致登陆和退出时 所设置的 cookie 路径不同。
ie比firefox要人性化,呵呵,当美指定路径时,会覆盖当前 ip 下的同名cookie变量,而firefox比较严格了,导致又重新建了个变量……
以上就是php cookie如何清除的详细内容。
其它类似信息

推荐信息