标签归档:cookie

php HTTP Cookies

透明地支持 » Netscape 规范定义中的 HTTP cookies。Cookies 是一种在远端浏览器端存储数据并能追踪或识别再次访问的用户的机制。可以用 setcookie() 函数设定 cookies。Cookies 是 HTTP 信息头中的一部分,因此 SetCookie 函数必须在向浏览器发送任何输出之前调用。对于 header() 函数也有同样的限制。 数据会在相应的 数据数组中可用,例如 $_,$HTTP__VARS 和 $_REQUEST。更多细节和例子见 setcookie() 手册页面。

如果要将多个值赋给一个 cookie 变量,必须将其赋成数组。例如:

<?php
  setcookie("MyCookie[foo]", 'Testing 1', time()+3600);
  setcookie("MyCookie[bar]", 'Testing 2', time()+3600);
?>
这将会建立两个单独的 cookie,尽管 MyCookie 在脚本中是一个单一的数组。如果想在仅仅一个 cookie 中设定多个值,考虑先在值上使用 serialize() 或 explode()。

注意在浏览器中一个 cookie 会替换掉上一个同名的 cookie,除非路径或者域不同。因此对于购物车程序可以保留一个计数器并一起传递,例如:

Example#4 一个 setcookie() 的示例

<?php
if (isset($_COOKIE['count'])) {
    $count = $_COOKIE['count'] + 1;
} else {
    $count = 1;
}
setcookie('count', $count, time()+3600);
setcookie("Cart[$count]", $item, time()+3600);
?>
变量名中的点
通常,PHP 不会改变传递给脚本中的变量名。然而应该注意到点(句号)不是 PHP 变量名中的合法字符。至于原因,看看:

<?php
$varname.ext;  /* 非法变量名 */
?>
这时,解析器看到是一个名为 $varname 的变量,后面跟着一个字符串连接运算符,后面跟着一个裸字符串(即没有加引号的字符串,且不匹配任何已知的健名或保留字)'ext'。很明显这不是想要的结果。

出于此原因,要注意 PHP 将会自动将变量名中的点替换成下划线。

确定变量类型

php cookie设置

一: 设置cookie

二: 设置cookie时的注意事项

三: setcookie举例

四: cookie的一些特点

五: 接收和处理cookie

六: 删除cookie

七: 使用cookie的限制

——来源与互联网,由blankyao整理

———————————-DESCRIPTION——————————————————-

一: 设置cookie

使用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__value”,time+3600,”/forum”,”http://www.128kj.com/”,1);

四: 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);

?>
<a href=”testcookie.php”>输出cookie</a> <br>
<a href=”deletecookie.php”>删除名为Testcookie的cookie</a>

2.处理
<?php
// 输出单独的 cookie
echo $_COOKIE["TestCookie"] . “<br>”;

// 另一个调试的方法就是输出所有的 cookie
print_r($_COOKIE);
echo “<BR>”.count($_COOKIE); //cookie的数量

3、删除
<?php
setcookie(”TestCookie”, “”, time() – 3600);

//输出testcookie
if (!empty($_COOKIE["TestCookie"]))
echo “Testcookie值为:”.$_COOKIE["TestCookie"] . “<br>”;
else
echo “Testcookie被注销。<br>”;
//输出testcookie1
echo “testcookie1值为:”.$_COOKIE["TestCookie1"] . “<br>”;
//输出所有cookie

print_r($_COOKIE);
?>

当一个Cookie被删除后,它的值在当前页仍然有效,刷新后才能生效。

六: 删除cookie

(1)调用只带有name参数的setcookie();

(2)使失效时间为time()或time-1;

七: 使用cookie的限制

(1) 必须在HTML文件的内容输出之前设置;

(2)不同的浏览器对cookie的处理不一致,使用时一定要考虑;

(3)客户端的限制,比如用户设置禁止cookie,则cookie不能建立;

八: 一个具体的例子,希望大家对cookie有更加深刻的认识

<?php

//cookie.php

if(!isset($flag)) {
setcookie(”mycookie”,”this my cookie!”);
header(”location:cookie.php?flag=1″);
exit;
}
?>