最新的Web开发教程
 

PHP setrawcookie() Function

<PHP HTTP参考

下面的示例创建与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参考