很多站长朋友们都不太清楚php去除cookie,今天小编就来给大家整理php去除cookie,希望对各位有所帮助,具体内容如下:
本文目录一览: 1、 PHP中cookie的清除 2、 php怎么删除cookie深入探讨 3、 PHP中如何删除Cookie 4、 请问:php如何清除网站根目录下的里面所有的Cookie呢? 5、 几种清除cookie有效方法(js,asp,php) 6、 php 清除COOKIE值的方法 PHP中cookie的清除setcookie('id','',time()-3600); 这里销毁的是id值 ,而你传过来的是echo "<a href='login.php?out=out'>退出</a>";中的out,是变量值销毁错了!
php怎么删除cookie深入探讨删除和种cookie都是用setcookie函数
区别就是cookie的过期参数,如果过期参数早于当前时间,则输出的时候就是删除cookie
例如要删除名为name1的cookie,只需设置name1的cookie过期时间为-1,就可删除了
PHP中如何删除Cookiesetcookie() 删除: // 将过期时间设为一小时前 1.setcookie("TestCookie", "", time() - 3600); PHP删除Cookie的方法就是把这个cookie的有效期设置为当前时间以前.2.setcookie("testcookie", '');或setcookie("cookiename", false);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手册中完全没有说明.定义和用法 setcookie() 函数向客户端发送一个 HTTP cookie。cookie 是由服务器发送到浏览器的变量。cookie 通常是服务器嵌入到用户计算机中的小文本文件。每当计算机通过浏览器请求一个页面,就会发送这个 cookie。cookie 的名称指定为相同名称的变量。例如,如果被发送的 cookie 名为 "name",会自动创建名为 $user 的变量,包含 cookie 的值。必须在任何其他输出发送前对 cookie 进行赋值。如果成功,则该函数返回 true,否则返回 false。语法 setcookie(name,value,expire,path,domain,secure)参数描述name必需。规定 cookie 的名称。value必需。规定 cookie 的值。expire可选。规定 cookie 的有效期。path可选。规定 cookie 的服务器路径。domain可选。规定 cookie 的域名。secure可选。规定是否通过安全的 HTTPS 连接来传输 cookie。提示和注释 注释:可以通过 $HTTP_COOKIE_VARS["user"] 或 $_COOKIE["user"] 来访问名为 "user" 的 cookie 的值。注释:在发送 cookie 时,cookie 的值会自动进行 URL 编码。接收时会进行 URL 解码。
请问:php如何清除网站根目录下的里面所有的Cookie呢?已经生成过的cookies是放在客户端上的,不在你的服务器上面,
其实你的服务器上并没有cookie,只有让他们访问到这句话,才能执行清理
你要把这句话放在公共文件中,就是不管点你网站的哪一个页面,都能访问到这句话,
自然也就处理了,如果只放在一个单一的页面,只有在你访问这个页面的时候才会执行清理
几种清除cookie有效方法(js,asp,php)几种清除
cookie有效方法(网页特效,asp教程,php教程)
网页特效设置cookie过期时间
<script
language="网页特效">
function
setcookie(name,days){var
url
=
document.domain;
var
exp
=
new
date();
exp.settime(exp.gettime()
+
days*24*60*60*1000);
document.cookie
=
name
+
"="+
escape(url)
+";expires="+
exp.togmtstring();}setcookie('domain',-1);
</script>asp清除cookieresponse.cookies("mycookie").expires=
(now()+1/24)
response.cookies("mycookie").expires
=
dateadd("h",
1,
now())
php 清除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 php去除特殊字符的详细内容...