温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

php cookie删除不了的解决办法

发布时间:2021-02-26 09:54:00 来源:亿速云 阅读:191 作者:清风 栏目:编程语言

这篇“php cookie删除不了的解决办法”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“php cookie删除不了的解决办法”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起来看看具体内容吧。

php cookie删除不了的解决办法:首先创建一个PHP示例文件;然后通过setcookie创建cookie;最后把这个cookie的有效期设置为当前时间以前的时间即可清除创建的cookie。

PHP无法删除COOKIE?设置COOKIE有效期

PHP 透明地支持 HTTP cookie,  cookie是一种在远程浏览器端存储数据并以此来跟踪和识别用户的机制。可以用setcookie() 或 setrawcookie()函数来设置cookie, cookie是HTTP标头的一部分,因此 setcookie()函数必须在其他信息被输出到浏览器前调用,这和对header()函数的限制类似。

setcookie();

删除cookie的方法是把这个cookie的有效期设置为当前时间以前

setcookie('test', 'true', time() + 300); // 创建 cookie
//setcookie('test',time() - 3600 );  // 清除建立的 cookie
//setcookie('test'); //只是将 $_COOKIE['test'] 的值清空
如果直接setcookie('test', '');
echo '';
print_r($_COOKIE); //attay();

会发现$_COOKIE数组是空的,而非仅仅$_COOKIE['test'] 为空,于是winsock抓包,观察返回的http 头,竟然是:

set-cookie:test=deleted; expires=Mon, 29-May-2014 10:22:15 GMT

登陆:

setcookie('username', 'zhangsan', time()+1000, "/php100");

退出:

setcookie('username', '', time()-3600);

发现做退出时 在IE下没问题,但是在Firefox中测试,登陆正常,无法退出,查看IE、Firefox中cookie记录的区别,经过测试才发现原来没有指定 setcookie()的第四个参数(合法路径参数),所以导致登陆和退出时所设置cookie的路径不同(Firefox比较严格,导致又重新建了各变量)

例:

$value = 'something';
setcookie('TestCookie', $value, time() + 3600);
setcookie('mytest', $value, time() + 3600, "~rasmus", ".maoge.com", 1);
if (isset($_COOKIE['TestCookie']))
{
echo 'TestCookie :' . $_COOKIE['TestCookie'];
}

感谢你的阅读,希望你对“php cookie删除不了的解决办法”这一关键问题有了一定的理解,具体使用情况还需要大家自己动手实验使用过才能领会,快去试试吧,如果想阅读更多相关知识点的文章,欢迎关注亿速云行业资讯频道!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI