PHP怎样使用Cookie_使用Cookie存储数据的操作【基础】

12次阅读

php中使用cookie需通过setcookie()设置并确保无输出前置,读取用$_COOKIE数组,删除需设过期时间且参数严格一致,验证可通过var_dump或浏览器开发者工具检查。

PHP怎样使用Cookie_使用Cookie存储数据的操作【基础】

如果您希望在PHP中使用Cookie来存储客户端数据,则需要通过http响应头向浏览器发送Set-Cookie指令。以下是实现Cookie存储与读取的基础操作步骤:

一、设置Cookie

使用setcookie()函数可向客户端发送Cookie,该函数必须在任何输出(包括空格和换行)发送到浏览器之前调用,否则会触发“headers already sent”错误。

1、确保php脚本顶部没有任何html输出、空行或bom字符。

2、调用setcookie()函数,传入名称、值、过期时间、路径、域名等参数,例如:setcookie(‘username’, ‘Alice’, time() + 3600, ‘/’);

立即学习PHP免费学习笔记(深入)”;

3、若需设置带HttpOnly和Secure标志的Cookie,可使用数组形式传递选项:setcookie(‘token’, ‘abc123’, [‘expires’ => time() + 86400, ‘path’ => ‘/’, ‘domain’ => ”, ‘secure’ => true, ‘httponly’ => true]);

二、读取Cookie

客户端每次请求时,浏览器会自动将匹配的Cookie通过HTTP请求头发送给服务器,PHP将其解析后存入$_COOKIE超全局数组中,可直接访问键名获取值。

1、检查Cookie是否存在,使用isset()判断:if (isset($_COOKIE[‘username’])) { echo $_COOKIE[‘username’]; }

2、直接输出Cookie值,例如:echo $_COOKIE[‘username’] ?? ‘未设置’;

3、遍历所有可用Cookie:foreach ($_COOKIE as $key => $value) { echo “$key = $value
“; }

三、删除Cookie

删除Cookie的本质是设置一个已过期的同名Cookie,使浏览器自动清除本地对应条目。仅unset($_COOKIE[‘name’])无法真正删除客户端Cookie。

1、设置过期时间为过去的时间戳,例如:setcookie(‘username’, ”, time() – 3600, ‘/’);

2、确保路径(path)和域名(domain)参数与原始设置完全一致,否则旧Cookie仍会保留。

3、如原Cookie设置了HttpOnly或Secure,删除时也需显式传入相同选项,否则可能无效:setcookie(‘token’, ”, [‘expires’ => time() – 3600, ‘path’ => ‘/’, ‘httponly’ => true, ‘secure’ => true]);

四、验证Cookie是否设置成功

可通过检查$_COOKIE数组或使用浏览器开发者工具application/Storage面板确认Cookie是否已写入,避免因缓存、路径不匹配或https环境缺失Secure标志导致失败。

1、在设置Cookie后立即刷新页面,并在下一次请求中检查$_COOKIE:var_dump($_COOKIE);

2、打开浏览器开发者工具,切换至Application标签页,在Cookies子项中查找当前域名下的条目。

3、确认Cookie的Expires/Max-Age、Path、Domain、Secure及HttpOnly字段与预期一致,特别注意:localhost环境下Secure标志会导致Cookie不被发送

text=ZqhQzanResources