PHP 简明教程

PHP Cookie

1. 什么是 Cookie?

Cookie 常用于识别用户。它是服务器嵌入到用户计算机中的一个小文件。每当同一台计算机通过浏览器请求页面时,它都会发送该 Cookie。

通过 PHP,您既可以创建 Cookie,也可以检索 Cookie 的值。

2. 在 PHP 中创建/修改 Cookie

在 PHP 中,使用 setcookie() 函数来创建一个 Cookie。

setcookie() 函数必须位于 <html> 标签之前。

2.1 语法

setcookie(name, value, expire, path, domain, secure, httponly);
参数描述
name必填。规定 Cookie 的名称。
value可选。规定 Cookie 的值。
expire可选。规定 Cookie 的有效期(Unix 时间戳)。
path可选。规定 Cookie 的服务器路径。
domain可选。规定 Cookie 的域名。
secure可选。规定是否仅通过安全的 HTTPS 连接传输。
httponly可选。若为 TRUE,则脚本无法访问 Cookie(有效防止 XSS 攻击)。

2.2 创建/检索 Cookie 示例

下例创建了一个名为 "user" 的 Cookie,值为 "Alex Porter",有效期为 30 天(86400 * 30 秒)。"/" 表示该 Cookie 在整个网站内可用(否则,您可以指定特定的目录)。

我们随后使用超全局变量 $_COOKIE 检索 Cookie 的值。同时使用 isset() 函数来检查 Cookie 是否已被设置:

代码示例:

<?php
$cookie_name = "user";
$cookie_value = "Alex Porter";
setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/"); // 86400 = 1 天
?>
<html>
<body>

<?php
if(!isset($_COOKIE[$cookie_name])) {
  echo "Cookie 名称 '" . $cookie_name . "' 尚未设置!";
} else {
  echo "Cookie '" . $cookie_name . "' 已设置!<br>";
  echo "值是: " . $_COOKIE[$cookie_name];
}
?>

</body>
</html>

注意:setcookie() 函数在发送 Cookie 时会自动对值进行 URL 编码,并在检索时自动解码。如果不希望进行编码,请改用 setrawcookie()

3. 修改 Cookie 值

要修改 Cookie,只需使用 setcookie() 函数再次设置该 Cookie 即可:

代码示例:

<?php
$cookie_name = "user";
$cookie_value = "John Doe";
setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/");
?>
<html>
<body>

<?php
if(!isset($_COOKIE[$cookie_name])) {
  echo "Cookie 名称 '" . $cookie_name . "' 尚未设置!";
} else {
  echo "Cookie '" . $cookie_name . "' 已设置!<br>";
  echo "值是: " . $_COOKIE[$cookie_name];
}
?>

</body>
</html>

4. 删除 Cookie

要删除 Cookie,请使用 setcookie() 函数并将过期日期设置为过去的时间点:

代码示例:

<?php
// 将过期时间设置为一小时前
setcookie("user", "", time() - 3600);
?>
<html>
<body>

<?php
echo "Cookie 'user' 已被删除。";
?>

</body>
</html>

5. 检查 Cookie 是否已启用

下例创建了一个简短的脚本,用以检查浏览器是否启用了 Cookie。首先,尝试使用 setcookie() 创建一个测试 Cookie,然后对 $_COOKIE 数组变量进行计数:

代码示例:

<?php
setcookie("test_cookie", "test", time() + 3600, '/');
?>
<html>
<body>

<?php
if(count($_COOKIE) > 0) {
  echo "Cookie 已启用。";
} else {
  echo "Cookie 已禁用。";
}
?>

</body>
</html>