当前位置: 首页 > 编程笔记 >

php 删除cookie方法详解

曾昂然
2023-03-14
本文向大家介绍php 删除cookie方法详解,包括了php 删除cookie方法详解的使用技巧和注意事项,需要的朋友参考一下

我们先来看下相关cookie的机制。


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

要删除cookie需要确保它的失效期是在过去,才能触发浏览器的删除机制。

下面的例子说明了如何删除刚才设置的cookie:


<?php

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

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

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

?>

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

以下代码可以在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);”会发送删除cookie的http头给浏览器。

最后我们可以得出结论:在php中使用“setcookie($cookiename, '');”或者“setcookie($cookiename, NULL);”都会删除cookie,当然这些手册中并没有。

是不是很简单呢,有时候我们还是非常有必要好好读读php源码的。

 类似资料:
  • 本文向大家介绍PHP 删除Cookie,包括了PHP 删除Cookie的使用技巧和注意事项,需要的朋友参考一下 示例 要删除Cookie,请将过期时间戳记设置为过去的时间。这将触发浏览器的删除机制: 删除Cookie时,请确保path和的domain参数setcookie()与您要删除的Cookie匹配,否则将创建一个立即过期的新Cookie。 $_COOKIE如果当前页面使用该值,则最好取消设置

  • 本文向大家介绍php批量删除cookie的简单实现方法,包括了php批量删除cookie的简单实现方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了php批量删除cookie的简单实现方法。分享给大家供大家参考。具体实现方法如下: 知识要点:如果把某个网站的所有cookie都删除了,则保存该网站cookie的文件,也将会被删除;如果只是删除其中一个cookie,则只在文件里的该cooki

  • 本文向大家介绍JS 新增Cookie 取cookie值 删除cookie 举例详解,包括了JS 新增Cookie 取cookie值 删除cookie 举例详解的使用技巧和注意事项,需要的朋友参考一下 cookie很实用的一个功能,可以判断某个状态,在项目中使用率极高

  • 如果cookie的max-age属性的值为0,则表示删除该cookie。cookie机制没有提供删除方法,因此通过设置该cookie即时失效实现删除cookie的效果。失效的cookie会被浏览器从cookie文件或者内存中删除。如: function delCookie(name) { setCookie(name, "", 0); }

  • 本文向大家介绍php及codeigniter使用session-cookie的方法(详解),包括了php及codeigniter使用session-cookie的方法(详解)的使用技巧和注意事项,需要的朋友参考一下 1、读写cookie <1>原生 设置失败,没有正常写入浏览器,测试失败,原因未知 <2>CI框架 <3>通过helper 2、读写session <1>原生session 启动: 赋

  • 本文向大家介绍php更新cookie内容的详细方法,包括了php更新cookie内容的详细方法的使用技巧和注意事项,需要的朋友参考一下 cookie 是由服务器发送到浏览器的变量。cookie 通常是服务器嵌入到用户计算机中的小文本文件。 每当计算机通过浏览器请求一个页面,就会发送这个 cookie。 (推荐学习:PHP视频教程) cookie 的名称指定为相同名称的变量。例如,如果被发送的 co