分类:
2009-03-16 15:58:39
使用cookie前必须设置cookie.
函数原型:int setcookie(string name,string value,int expire,string path,string domain,int secure)
其中,除name外,所有的参数都是可选的,可以用空的字符串表示未设置.
属性value: 用来指定值.
属性path: 用来指定cookie被发送到服务器的哪一个目录路径下.属性domain:能够在浏览器端对cookie的发送进行限定.
expire参数:用来指定cookie的有效时间,它是一个标准的Unix时间标记.
可以用time()或者mktime()函数取得,以秒为单位.
secure参数:表示这个cookie是否通过加密的HTTPS协议在网络上传输.
二: 设置cookie时的注意事项
在同一个页面中设置cookie,实际上是按从后往前的顺序进行的.如果要先删除一个cookie,再写入一个cookie,则必须先写写入语句,再写删除语句.否则会出现错误.
三: setcookie举例
简单的: setcookie(”mycookie”,”value_of_mycookie”);
带失效时间的: setcookie(”withExpire”,”Expire_in_1_hour”,time()+3600);
什么都有的:setcookie(”FullCookie”,”Full_cookie_value”,time+3600,”/forum”,”);
四: cookie的一些特点
cookie是面向路径的.缺省path属性时,WEB服务器页会自动传递当前路径给浏览器.指定路径会强制服务器使用设置的路径.
在一个目录页面里设的cookie在另一个目录的页面里是看不到的.
五: 接收和处理cookie
1.设置
$value = ‘i like php’;
$value1= ‘i hate php’;
setcookie(”TestCookie”, $value,time()+3600); /* expire in 1 hour */
setcookie(”TestCookie1″, $value1);
?>
输出cookie
删除名为Testcookie的cookie
2.处理
// 输出单独的 cookie
echo $_COOKIE["TestCookie"] . “
”;
// 另一个调试的方法就是输出所有的 cookie
print_r($_COOKIE);
echo “
”.count($_COOKIE); //cookie的数量
3、删除
setcookie(”TestCookie”, “”, time() - 3600);
//输出testcookie
if (!empty($_COOKIE["TestCookie"]))
echo “Testcookie值为:”.$_COOKIE["TestCookie"] . “
”;
else
echo “Testcookie被注销。
”;
//输出testcookie1
echo “testcookie1值为:”.$_COOKIE["TestCookie1"] . “
”;
//输出所有cookie
print_r($_COOKIE);
?>
当一个Cookie被删除后,它的值在当前页仍然有效,刷新后才能生效。
六: 删除cookie
(1)调用只带有name参数的setcookie();
(2)使失效时间为time()或time-1;
七: 使用cookie的限制
(1) 必须在HTML文件的内容输出之前设置;
(2)不同的浏览器对cookie的处理不一致,使用时一定要考虑;
(3)客户端的限制,比如用户设置禁止cookie,则cookie不能建立;
八: 一个具体的例子,希望大家对cookie有更加深刻的认识
//cookie.php
if(!isset($flag)) {
setcookie(”mycookie”,”this my cookie!”);
header(”location:cookie.php?flag=1″);
exit;
}
?>