例
下面的示例创建与PHP的cookie。 该cookie被命名为"user"和值将是"John Doe" 。 cookie的值不会被URL编码。 经过30天的cookie将过期(86400 * 30) 使用"/" ,意味着该Cookie是在整个网站上提供(otherwise, select the directory you prefer) :
<?php
$cookie_name = "user";
$cookie_value = "John";
setrawcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
//
86400 = 1 day
?>
<html>
<body>
<?php
echo "Cookie is set.";
?>
</body>
</html>
?>
运行示例» 定义和用法
所述setrawcookie()函数定义一个cookie (without URL encoding)以沿着与所述HTTP标头的其余部分被发送。
Cookie通常用来识别用户。 Cookie是服务器在用户的计算机中的小文件。 每当计算机请求一个页面浏览器时,它就会发送cookie。 使用PHP,您可以创建并取回cookie的值。
Cookie的名字被自动分配到同一名称的变量。 例如,如果一个cookie用的名称发送"user" ,一个变量被自动创建名为$用户,包含cookie值。
Note:该setrawcookie()函数必须出现在之前<html>标记。
Note:要自动URL编码发送时,并且自动接收时进行解码,使用cookie值setcookie()函数来代替。
句法
setrawcookie( name,value,expire,path,domain,secure );
参数 | 描述 |
---|---|
name | 需要。 指定cookie的名称 |
value | 可选的。 指定cookie的值 |
expire | 可选的。 指定当Cookie过期。 值: time() + 86400 * 30,将设置Cookie在30天后过期。 如果未设置此参数,cookie将在会议结束时到期(when the browser closes) |
path | 可选的。 规定cookie的服务器路径。 如果设置为"/"时,cookie将是整个域内可用。 如果设置为"/php/"时,cookie将只能是php目录和PHP的所有子目录中可用。 默认值是该Cookie在所设定的当前目录 |
domain | 可选的。 规定cookie的域名。 为了使在example.com的所有子域提供的饼干,设置域".example.com" 。 如果设置为www.example.com将会使饼干只在www子域可用 |
secure | 可选的。 规定是否该cookie只能通过安全的HTTPS连接来传输。 TRUE表明,如果安全连接存在cookie将只设置。 默认为false。 |
技术细节
返回值: | TRUE成功。 FALSE失败 |
---|---|
PHP版本: | 5+ |
更多示例
例
检索名为cookie的值"user" (使用全局变量$ _COOKIE)。 还可以使用isset()的功能,以找出是否该cookie存在:
<html>
<body>
<?php
$cookie_name = "user";
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' does not
exist!";
} else {
echo "Cookie is named: " . $cookie_name
. "<br>Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
运行示例» 例
要修改一个cookie,只需将(again)使用该cookie setrawcookie()函数:
<?php
$cookie_name = "user";
$cookie_value = "Alex";
setrawcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
?>
<html>
<body>
<?php
$cookie_name = "user";
if(!isset($_COOKIE[$cookie_name]))
{
echo "Cookie named '" . $cookie_name . "' does not
exist!";
} else {
echo "Cookie is named: " . $cookie_name
. "<br>Value is: " . $_COOKIE[$cookie_name];
}
?>
</body>
</html>
运行示例» 例
要删除Cookie,使用setrawcookie()函数,在过去的到期日期:
<?php
$cookie_name = "user";
unset($_COOKIE[$cookie_name]);
// empty value and expiration one hour
before
$res = setrawcookie($cookie_name, '', time() - 3600);
?>
<html>
<body>
<?php
echo "Cookie 'user'
is deleted.";
?>
</body>
</html>
运行示例» 例
创建一个小的脚本来检查是否cookies被启用。 首先,尝试创建一个测试Cookie与setrawcookie()函数,然后计算$ _COOKIE数组变量:
<?php
setrawcookie("test_cookie", "test" , time() + 3600, '/');
?>
<html>
<body>
<?php
if(count($_COOKIE) > 0) {
echo "Cookies are enabled";
} else {
echo "Cookies
are disabled";
}
?>
</body>
</html>
运行示例» <PHP HTTP参考