# setcookie(name, value, expire, path, domain); // is a function for set
# 打印cookie信息 print_r($_COOKIE);
先来讲讲php中setcookie的相关定义:
setcookie() 定义一个和其余的 HTTP 标头一起发送的 cookie。和其它标头一样,cookie 必须在脚本的任何其它输出之前发送(这是协议限制)。这需要将本函数的调用放到任何输出之前,包括 和
标签以及任何空格。如果在调用 setcookie() 之前有任何输出,本函数将失败并返回 FALSE。如果 setcookie() 函数成功运行,将返回 TRUE。这并不说明用户是否接受了 cookie。函数定义:
bool
setcookie() 参数详解
参数 | 说明 | 举例 |
---|---|---|
name | Cookie 的名字。 | 使用 |
value | Cookie 的值。此值保存在客户端,不要用来保存敏感数据。 | 假定 |
expire | Cookie 过期的时间。这是个 Unix 时间戳,即从 Unix 纪元开始的秒数。换而言之,通常用 | time()+60*60*24*30 |
path | Cookie 在服务器端的有效路径。 | 如果该参数设为 |
domain | 该 cookie 有效的域名。 | 要使 cookie 能在如 example.com 域名下的所有子域都有效的话,该参数应该设为 |
secure | 指明 cookie 是否仅通过安全的 HTTPS 连接传送。当设成 | 0 |
下面一些例子说明了如何发送 cookie:
例子 1. setcookie() 发送例子
$value = 'something from somewhere';
setcookie("TestCookie", $value);
setcookie("TestCookie", $value,time()+3600);
setcookie("TestCookie", $value,time()+3600, "/~rasmus/", ".utoronto.ca", 1);
注意 cookie 中值的部分在发送的时候会被自动用 urlencode 编码并在接收到的时候被自动解码并把值赋给与自己同名的 cookie 变量。如果不想这样并且在使用 PHP 5 的话,可以用 setrawcookie() 来代替。下面这个简单的例子可以得到刚才所设定的 cookie 的值: