分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

PHP使用cookie时遇到的坑

发布时间:2023-09-06 01:17责任编辑:彭小芳关键词:PHP

先看这么一段代码

<?phpdate_default_timezone_set("Etc/GMT-8");if(!isset($_COOKIE["visittime"])){//如果Cookie不存在 setcookie("visittime",date("y-m-d H:i:s")); //设置一个Cookie变量echo "first time to meet:".date("y-m-d H:i:s")."<br>";//输出字符串}else{//如果Cookie存在setcookie("visittime",date("y-m-d H:i:s"),time()+60); //设置带Cookie失效时间的变量 ???????echo "last time:".$_COOKIE["visittime"];//输出上次访问网站的时间echo "<br>"; ????????//输出回车符}echo "now: ".date("y-m-d H:i:s");//输出当前的访问时间?>

 

第一次运行该程序的结果如下图:

然后我刷新了一次,运行结果如下图

你如果不细心,一定没发现,第二次运行的last time的值,正是第一次运行时保存的值。

先看代码,如果$_COOKIE[‘visititme‘]没有赋值,就输出first meet 。。。和now

但是第二次运行的时候,$_COOKIE[‘visittime‘]已经被赋过值了,应该执行if(){   }  else {  }的else部分,也就是重新对visittime赋值,然后输出新赋的值和now,但是结果并没有和我预想的一样,重新对visittime赋值失败了,其依旧保存的是旧值,我翻手册,手册上是这样说的:

  • 为同一个参数再次设置 Cookie 前,必须先把它删掉。 如果参数的值是空 string 或 FALSE,并且其他参数和上次调用 setcookie 仍旧一样, 则指定的名称会被远程客户端删除。 内部的实现是:将值设置成 ‘deleted‘,并且过期时间是一年前。    

现在才知道为什么会这样了,真是一个坑。。。。。

PHP使用cookie时遇到的坑

原文地址:http://www.cnblogs.com/-beyond/p/7658944.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved