PHP编程:php 删除cookie方法详解
《php 删除cookie方法详解》要点: PHP编程我们先来看下相关cookie的机制.
代码如下:
bool setcookie ( string name [,string value [,int expire [,string path [,string domain [,bool secure]]]]] ) PHP编程要删除cookie必要确保它的失效期是在过去,才能触发浏览器的删除机制. PHP编程下面的例子说明了如何删除刚才设置的cookie:
代码如下:
<?php //将过期时间设为一小时前 setcookie("TestCookie","",time() - 3600); setcookie("TestCookie",time() - 3600,"/~rasmus/",".utoronto.ca",1); ?> PHP编程删除一个cookie的办法就是把这个cookie的有效期设置为当前时间以前,这也是几乎所有php程序员都会这么做. PHP编程后来一个初接触php的朋友告诉我,他在程序中本想把一个cookie的值设置为空,结果导致这个cookie直接被删除.我当时的第一反应是不相信,于是测试
代码如下:
setcookie("testcookie",''); print_r($_COOKIE); PHP编程结果果然是整个$_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编程最后阅读php源码,终于发现真相(这就是开源的好处了,有什么不清楚的内幕,直接查源码). PHP编程以下代码可以在php5.20的linux源码包中ext/standard/head.c第99行附近找到:
代码如下:
if (value && value_len == 0) { ??? /* ???? * MSIE doesn't delete a cookie when you set it to a null value ???? * so in order to force cookies to be deleted,even on MSIE,we ???? * pick an expiry date 1 year and 1 second in the past ???? */ ??? 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",value ? encoded_value : ""); ??? if (expires > 0) { ??????? strcat(cookie,"; expires="); ??????? dt = php_format_date("D,expires,0 TSRMLS_CC); ??????? strcat(cookie,dt); ??????? efree(dt); ??? } } PHP编程源码中清清楚楚的显示“if (value && value_len == 0)”,当“value_len”为0时,“sprintf(cookie,dt);”会发送删除cookie的http头给浏览器. PHP编程最后我们可以得出结论:在php中使用“setcookie($cookiename,'');”或者“setcookie($cookiename,NULL);”都会删除cookie,当然这些手册中并没有. PHP编程是不是很简单呢,有时候我们还是非常有需要好好读读php源码的. 《php 删除cookie方法详解》是否对您有启发,欢迎查看更多与《php 删除cookie方法详解》相关教程,学精学透。编程之家 52php.cn为您提供精彩教程。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |