PHP setcookie() 函数
定义和用法
setcookie()
函数用于定义与其余 HTTP 标头一起发送的 cookie。
Cookie 常用于识别用户。Cookie 是服务器嵌入到用户计算机上的小文件。每次同一台计算机通过浏览器请求页面时,它都会发送该 cookie。使用 PHP,您可以创建和检索 cookie 值。
Cookie 的名称会自动分配给同名的变量。例如,如果发送了一个名为 "user"
的 cookie,则会自动创建一个名为 $user
的变量,其中包含 cookie 的值。
注意:setcookie()
函数必须出现在 <html>
标签之前。
注意:发送 cookie 时,cookie 的值会自动进行 URL 编码;接收时,会自动进行解码(要防止 URL 编码,请使用 setrawcookie()
代替)。
实例
例子 1
下例创建了一个名为 "user"
的 Cookie,其值为 "Bill Gates"
。该 Cookie 将在 30 天后过期(86400 * 30)。"/"
表示该 Cookie 在整个网站中都可用(否则,请选择您喜欢的目录)。
然后,我们检索名为 "user"
的 Cookie 的值(使用全局变量 $_COOKIE
)。我们还使用 isset()
函数来检查 Cookie 是否已设置:
<!DOCTYPE html> <?php $cookie_name = "user"; $cookie_value = "Bill Gates"; setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/"); // 86400 = 1 天 ?> <html> <body> <?php if(!isset($_COOKIE[$cookie_name])) { echo "名为 '" . $cookie_name . "' 的 Cookie 未设置!"; } else { echo "名为 '" . $cookie_name . "' 的 Cookie 已设置!<br>"; echo "值为: " . $_COOKIE[$cookie_name]; } ?> </body> </html>
例子 2
为 cookie 设置多个过期日期:
<?php $value = "Hello world!"; // 当浏览器关闭时,cookie 将过期 setcookie("myCookie", $value); // cookie 将在 1 小时后过期 setcookie("myCookie", $value, time() + 3600); // cookie 将在 1 小时后过期,并且仅可在 // php 目录及其所有子目录中使用 setcookie("myCookie", $value, time() + 3600, "/php/"); ?> <html> <body> ...一些代码... </body> </html>
例子 3
要修改 cookie,只需再次使用 setcookie()
函数设置 cookie:
<?php $cookie_name = "user"; $cookie_value = "Alex Porter"; setcookie($cookie_name, $cookie_value, time() + (86400 * 30), "/"); ?> <html> <body> <?php if(!isset($_COOKIE[$cookie_name])) { echo "名为 '" . $cookie_name . "' 的 cookie 没有设置!"; } else { echo "名为 '" . $cookie_name . "' 的 cookie 已设置!<br>"; echo "值为: " . $_COOKIE[$cookie_name]; } ?> </body> </html>
例子 4
要删除 cookie,请将 setcookie()
函数的过期日期设置为过去的时间:
<?php // 将过期日期设置为一小时前 setcookie("user", "", time() - 3600); ?> <html> <body> <?php echo "名为 'user' 的 cookie 已删除。"; ?> </body> </html>
例子 5
创建一个小脚本来检查 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>
语法
setcookie(name, value, expire, path, domain, secure, httponly);
参数值
参数 | 描述 |
---|---|
name | 必需。指定 cookie 的名称。 |
value | 可选。指定 cookie 的值。 |
expire |
可选。指定 cookie 的过期时间。 值 time()+86400*30 将使 cookie 在 30 天后过期。 如果省略此参数或设置为 0,cookie 将在会话结束时(即浏览器关闭时)过期。 默认为 0。 |
path |
可选。指定 cookie 的服务器路径。 如果设置为 "/",则 cookie 对整个域都可用。 如果设置为 "/php/",则 cookie 仅对 php 目录及其所有子目录可用。 默认值是设置 cookie 的当前目录。 |
domain |
可选。指定 cookie 的域名。 要使 cookie 在 example.com 的所有子域中都可用,请将 domain 设置为 "example.com"。 将其设置为 www.example.com 将使 cookie 仅在 www 子域中可用。 |
secure |
可选。指定是否仅通过安全的 HTTPS 连接传输 Cookie。 TRUE 表示仅当存在安全连接时才设置 Cookie。 默认为 FALSE。 |
httponly |
可选。如果设置为 TRUE,则 Cookie 仅能通过 HTTP 协议访问(Cookie 无法通过脚本语言访问)。 此设置有助于减少通过 XSS 攻击进行的身份盗用。 默认为 FALSE。 |
技术细节
返回值: | 成功时返回 TRUE,失败时返回 FALSE。 |
---|---|
PHP 版本: | 4+ |
PHP 更新日志: |
PHP 5.5 - 在发送到客户端的 Set-Cookie 标头中包含了 Max-Age 属性; PHP 5.2 - 添加了 httponly 参数。 |