用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > php教程

php setcookie值为null或空字符串删除cookie解析

时间:2015-01-23  来源:西部数据  作者:西部数据

很多朋友在使用setcookie设置值为空或NULL时系统会自动把cookie给删除掉,下面我来给大家分析cookie值为null或空字符串删除cookie原因吧,有需要学习的朋友可参考,官方文档中也是这样写的:

setcookie() delete example

  1. <?php 
  2. // set the expiration date to one hour ago 
  3. setcookie ("TestCookie""", time() - 3600); 
  4. setcookie ("TestCookie""", time() - 3600, "/~rasmus/""example.com", 1); 
  5. ?> 

今天遇到一件奇怪的事,在setcookie的时候,传了一个空字符串给$value,结果竟然是此cookie被删除了…代码如下:

  1. $name = "post_url"
  2. $value =  ""
  3. setcookie($name$value,  time()+60*60*3, "/" ); 

去翻php 5.4.13 的源码结果得知,参数中的value在C语言中的类型是char *,还有一个 value_len标明了它的长度,如果value_len为0的话,就写了下面的cookie:

值为”deleted”, 过期时间为 Thu, 01-Jan-1970 08:00:01 CST 或者说是 Thu, 01-Jan-1970 00:00:01 GMT,看来setcookie($name, “”) 确实可以删除这个cookie了…

同理,在php中,strval(NULL) === “” , 所以 setcookie($name, NULL) 也就相当于 setcookie($name, “”),同样可以删除此cookie.

来顶一下
返回首页
返回首页
推荐资讯
WiFi太不安全:7岁女孩11分钟内入侵公共网络 WiFi太不安全:7岁女孩11分钟内入侵近期刚刚发布研究说WiFi网络能获得人们手机里多少私人信息,
不服跑个分?人工智能也出现“刷分”乱象 不服跑个分?人工智能也出现“刷分2014年,人工智能领域突然爆发,成为了科研和科技创业的热门
相关文章
栏目更新
栏目热门