热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

php删除cookie的实现方法-PHP问题

php删除cookie的实现方法:1、通过“setCookie("name","",time()-60);”删除单个cookie;2、采用foreach遍历数组的方式删除多个cookie。

php删除COOKIE的实现方法:1、通过“setCOOKIE("name","",time()-60);”删除单个COOKIE;2、采用foreach遍历数组的方式删除多个COOKIE。

推荐:《PHP视频教程》

php 删除COOKIE

php批量删除COOKIE的简单实现方法

代码如下:

$value){
 setCOOKIE($key,"",time()-60);
}
?>

知识要点:如果把某个网站的所有COOKIE都删除了,则保存该网站COOKIE的文件,也将会被删除;如果只是删除其中一个COOKIE,则只在文件里的该COOKIE信息被删除。

PHP COOKIE的使用

1、设置COOKIE

PHP用SetCOOKIE函数来设置COOKIE。必须注意的一点是:COOKIE是HTTP协议头的一部分 ,用于浏览器和服务器之间传递信息,所以必须 在任何属于HTML文件本身的内容输出之前调用 COOKIE函数。

SetCOOKIE函数定义了一个COOKIE,并且把它附加在HTTP头的后面,SetCOOKIE函数的原型如下:

int SetCOOKIE(string name, string value, int expire, string path, string domain, int secure);

除了name之外所有的参数都是可选的。value,path,domain三个参数可以用空字符串代换,表示没有设置;expire 和 secure两个参数是数值型的,可以用0表示。expire 参数是一个标准的Unix时间标记 ,可以用time()或mktime()函数取得,以秒为 单位。

secure 参数表示这个COOKIE是否通过加密 的HTTPS 协议在网络上传输。

当前设置的COOKIE不是立即生效的,而是要等到下一个页面时才能看到.这是由于在设置的这个页面里COOKIE由服务器传递给客户浏览器,在下一个页面浏览器才能把COOKIE从客户的机器里取出传回服务器的原因。

在同一个页面设置COOKIE,实际是从后往前,所以如果要在插入一个新的COOKIE之前删掉一个,你必须先写插入的语句,再写删除的语句,否则可能会出现不希望的结果。

来看几个例子:

简单的:

SetCOOKIE("MyCOOKIE", "Value of MyCOOKIE");

带失效时间的:

SetCOOKIE("WithExpire", "Expire in 1 hour", time()+3600);//3600秒=1小时

什么都有的:

SetCOOKIE("FullCOOKIE", "Full COOKIE value", time()+3600, "/forum", ".phpuser.com", 1);

这里还有一点要说明的,比如你的站点有几个不同的目录,那么如果只用不带路径的COOKIE的话,在一个目录下的页面里设的COOKIE在另一 个目录的页面里是看不到的,也就是说,COOKIE是面向路径的。实际上 ,即使没有指定路径,WEB服务器会自动传递当前的路径给浏览器的,指定路径会强 制服务器使用设置的路径。解决这个问题的办法是在调用SetCOOKIE时加上路径和域名,域名的格式可以是“www.phpuser.com”,也可是 “. phpuser.com”。

SetCOOKIE函数里表示value的部分,在传递时会自动被encode ,也就是说,如果 value的值是“test value”在传递时就变成了“test%20value”,跟URL的方法一样。当然,对于程序来说这是透明的,因为在PHP接收COOKIE的值时会 自动将其decode。

如果要设置同名的多个COOKIE ,要用数组,方法是:

SetCOOKIE("COOKIEArray[]", "Value 1");
SetCOOKIE("COOKIEArray[]", "Value 2");

SetCOOKIE("COOKIEArray[0]", "Value 1");
SetCOOKIE("COOKIEArray[1]", "Value 2");

2、接收和处理COOKIE

PHP对COOKIE的接收和处理的支持非常好,是完全自动的,跟FORM变量的原则一样,特别简单。

比如设置一个名为 MyCOOKIEr的COOKIE,PHP会自动从WEB服务器接收的HTTP头里把它分析出来,并形成一个与普通变量一样的变量,名为$ myCOOKIE,这个变量的值就是COOKIE的值。数组同样适用。另外一个办法是引用PHP的全局变量$HTTP_COOKIE_VARS数组。

分别举例如下:(假设这些都在以前的页面里设置过了,并且仍然有效)

echo $MyCOOKIE;
echo $COOKIEArray[0];
echo count($COOKIEArray);
echo $HTTP_COOKIE_VARS["MyCOOKIE"];

就这么简单。

3、删除COOKIE

要删除一个已经存在的COOKIE,有两个办法:

一是调用只带有name参数 的SetCOOKIE,那么名为这个name的COOKIE将被从关系户机上删掉;

另一个办法是设置COOKIE的失效时间为time()或time()-1 ,那么这个COOKIE在这个页面的浏览完之后就被删除了(其实是失效了)。

要注意的是,当一个COOKIE被删除时,它的值在当前页在仍然有效的。

4、使用COOKIE的限制

首先是必须在HTML文件的内容输出之前设置;

其次不同的浏览器对COOKIE的处理不一致辞,且有时会出现错误的结果。比如: MS IE+SERVICE PACK 1不能正确处理带域名和路径的COOKIE,Netscape Communicator 4.05和MS IE 3.0不能正确处理不带路径和时间的COOKIE。至于MS IE 5 好象不能处理带域名、路径和时间的COOKIE。这是我在设计本站的页面时发现的。

第三个限制是在客户端的。

一个浏览器能 创建的COOKIE数量最多为30个,并且每个 不能超过4KB ,每个WEB站点 能设置的COOKIE总数不能超过20个 。

PHP 删除COOKIE 方法

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

------以下引用php手册内容--------------

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);
----------------引用结束--------------------------

删除一个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删除COOKIE的实现方法的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • 本文介绍了在开发Android新闻App时,搭建本地服务器的步骤。通过使用XAMPP软件,可以一键式搭建起开发环境,包括Apache、MySQL、PHP、PERL。在本地服务器上新建数据库和表,并设置相应的属性。最后,给出了创建new表的SQL语句。这个教程适合初学者参考。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 如何实现织梦DedeCms全站伪静态
    本文介绍了如何通过修改织梦DedeCms源代码来实现全站伪静态,以提高管理和SEO效果。全站伪静态可以避免重复URL的问题,同时通过使用mod_rewrite伪静态模块和.htaccess正则表达式,可以更好地适应搜索引擎的需求。文章还提到了一些相关的技术和工具,如Ubuntu、qt编程、tomcat端口、爬虫、php request根目录等。 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • 这是原文链接:sendingformdata许多情况下,我们使用表单发送数据到服务器。服务器处理数据并返回响应给用户。这看起来很简单,但是 ... [详细]
  • Centos7.6安装Gitlab教程及注意事项
    本文介绍了在Centos7.6系统下安装Gitlab的详细教程,并提供了一些注意事项。教程包括查看系统版本、安装必要的软件包、配置防火墙等步骤。同时,还强调了使用阿里云服务器时的特殊配置需求,以及建议至少4GB的可用RAM来运行GitLab。 ... [详细]
  • 禁止程序接收鼠标事件的工具_VNC Viewer for Mac(远程桌面工具)免费版
    VNCViewerforMac是一款运行在Mac平台上的远程桌面工具,vncviewermac版可以帮助您使用Mac的键盘和鼠标来控制远程计算机,操作简 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文介绍了在Mac上搭建php环境后无法使用localhost连接mysql的问题,并通过将localhost替换为127.0.0.1或本机IP解决了该问题。文章解释了localhost和127.0.0.1的区别,指出了使用socket方式连接导致连接失败的原因。此外,还提供了相关链接供读者深入了解。 ... [详细]
  • Webmin远程命令执行漏洞复现及防护方法
    本文介绍了Webmin远程命令执行漏洞CVE-2019-15107的漏洞详情和复现方法,同时提供了防护方法。漏洞存在于Webmin的找回密码页面中,攻击者无需权限即可注入命令并执行任意系统命令。文章还提供了相关参考链接和搭建靶场的步骤。此外,还指出了参考链接中的数据包不准确的问题,并解释了漏洞触发的条件。最后,给出了防护方法以避免受到该漏洞的攻击。 ... [详细]
  • Linux磁盘的分区、格式化的观察和操作步骤
    本文介绍了如何观察Linux磁盘的分区状态,使用lsblk命令列出系统上的所有磁盘列表,并解释了列表中各个字段的含义。同时,还介绍了使用parted命令列出磁盘的分区表类型和分区信息的方法。在进行磁盘分区操作时,根据分区表类型选择使用fdisk或gdisk命令,并提供了具体的分区步骤。通过本文,读者可以了解到Linux磁盘分区和格式化的基本知识和操作步骤。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • 本文介绍了一种处理AJAX操作授权过期的全局方式,以解决Asp.net MVC中Session过期异常的问题。同时还介绍了基于WebImage的图片上传工具类。详细内容请参考链接:https://www.cnblogs.com/starluck/p/8284949.html ... [详细]
author-avatar
猪猪爱tai旸
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有