您的位置:首页 > 编程语言 > PHP开发

深入解读PHP删除Cookie技巧

2013-05-29 19:03 387 查看
PHP语言是一款功能强大的嵌入式HTML语言。它的应用范围非常广泛,在这里我们就为大家介绍有关PHP删除Cookie的技巧应用。

首先我们看一下PHP手册中关于PHP删除Cookie的说明

bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )

要删除 cookie 需要确保它的失效期是在过去,才能触发浏览器的删除机制。下面的例子说明了如何删除刚才设置的 cookie: 例子 2. setcookie() 删除

例子

// 将过期时间设为一小时前

setcookie("TestCookie", "", time() - 3600);

setcookie("TestCookie", "", time() - 3600, "/~rasmus/", ".utoronto.ca", 1);

PHP删除Cookie的方法就是把这个cookie的有效期设置为当前时间以前,这也是几乎所有PHP程序员都会这么做。

后来一个初接触PHP的朋友告诉我,他在程序中本想把一个cookie的值设置为空,结果导致这个cookie直接被删除。我当时的第一反应是不相信,于是测试了一下

setcookie("testcookie", '');

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删除Cookie源码,终于发现真相(这就是开源的好处了,有什么不清楚的内幕直接查源码)

以下PHP删除Cookie代码可以在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",
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);

会发送PHP删除Cookie的http头给浏览器.最后我们可以得出结论,在PHP中使用

setcookie($cookiename, '');或者 setcookie($cookiename, NULL);

都会实现PHP删除Cookie,当然这些手册中并没有。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: