0

0

如何正确使用 PHP 设置包含数组数据的 Cookie

心靈之曲

心靈之曲

发布时间:2026-03-08 16:00:02

|

947人浏览过

|

来源于php中文网

原创

如何正确使用 PHP 设置包含数组数据的 Cookie

本文详解 php 中通过表单复选框触发设置 json 序列化 cookie 的完整实现,涵盖安全写法、时间戳有效期、重定向刷新机制及调试验证方法。

本文详解 php 中通过表单复选框触发设置 json 序列化 cookie 的完整实现,涵盖安全写法、时间戳有效期、重定向刷新机制及调试验证方法。

在 Web 开发中,利用复选框()作为用户确认动作并同步持久化数据(如配置项、偏好设置)到客户端 Cookie 是常见需求。但许多开发者会遇到“点击后 Cookie 未生效”的问题——这通常并非逻辑错误,而是源于 PHP setcookie() 的底层约束与典型实践疏漏。

关键限制与修复原则

PHP 的 setcookie() 函数必须在任何输出发送至浏览器前调用(即不能在 echo、HTML 内容或空白字符之后执行),否则将因 HTTP 头已发送而静默失败。此外,直接使用 extract($_POST) 存在严重安全隐患(可能覆盖关键变量、引发变量污染),应严格避免。

同时,Cookie 过期时间必须为绝对时间戳(Unix timestamp),而非相对秒数。原代码中 86500 被误作过期时间,实则应为 time() + 86400(即 24 小时后)。更推荐使用 time() + 3600(1 小时)便于本地测试。

正确实现:重定向驱动的状态同步

最佳实践是采用「表单提交 → 服务端处理 Cookie → 302 重定向回原页」流程,确保:

方舟订单管理系统
方舟订单管理系统

系统开发由二当家的编写,代码完全开源,可自行修改源码,欢迎使用! 1、网站采用php语言开发,更安全、稳定、无漏洞、防注入、防丢单。 2、记录订单来路,客户IP记录及分析,订单数据统计 3、订单邮件提醒、手机短信提醒,让您第一时间追踪订单,大大提升了发货效率,提高订单成交率。 4、多种支付方式,包含:货到付款、支付宝接口、网银支付,可设置在线支付的折扣比率。 5、模板样式多样化,一个订单放到多个网

下载

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

  • Cookie 在响应头中正确写入;
  • 页面重新加载后能立即读取最新 Cookie 状态;
  • 用户操作反馈清晰(如显示 “Saved”)。

以下是经过安全加固与逻辑优化的完整示例:

<?php
// 处理表单提交(仅在 POST 请求时执行)
if ($_SERVER['REQUEST_METHOD'] === 'POST' && isset($_POST['save']) && $_POST['save'] === '1') {
    // 获取并过滤输入(生产环境建议用 filter_input)
    $code  = $_POST['code'] ?? '';
    $total = (int)($_POST['total'] ?? 0);

    // 构建结构化数据并序列化
    $cookieData = [
        'name'  => $code,
        'value' => $total
    ];

    // 设置 Cookie:名称、JSON 值、过期时间(1 小时后)、路径(/ 全站有效)
    setcookie(
        'cookie',
        json_encode($cookieData),
        [
            'expires' => time() + 3600,
            'path'    => '/',
            'secure'  => false, // HTTPS 环境请设为 true
            'httponly'=> true,   // 防 XSS,禁止 JS 访问
            'samesite'=> 'Lax'
        ]
    );

    // 强制重定向,避免重复提交 & 确保 Cookie 可读
    header('Location: ' . $_SERVER['PHP_SELF']);
    exit;
}
?>

<!-- 表单部分 -->
<form method="post">
    <label>
        <input type="checkbox" name="save" value="1"> Save to Cookie
    </label><br>
    <input type="text" name="code" placeholder="Enter identifier (e.g., 'theme')" required><br>
    <input type="number" name="total" placeholder="Enter numeric value" value="100" min="0"><br>
    <button type="submit">Submit</button>
</form>

<!-- 状态反馈区域 -->
<div style="margin-top: 20px; padding: 10px; background: #f5f5f5;">
<?php if (isset($_COOKIE['cookie'])): ?>
    <?php $data = json_decode($_COOKIE['cookie'], true); ?>
    <strong>✅ Cookie SET:</strong><br>
    Name: <?= htmlspecialchars($data['name'] ?? 'N/A') ?><br>
    Value: <?= (int)($data['value'] ?? 0) ?><br>
    Expires: <?= date('Y-m-d H:i:s', $_COOKIE['cookie_expire'] ?? time() + 3600) ?>
<?php else: ?>
    <strong>❌ Cookie NOT SET</strong><br>
    Tick the checkbox and submit to save.
<?php endif; ?>
</div>

注意事项与进阶建议

  • 安全性强化:始终对用户输入进行过滤(如 filter_input(INPUT_POST, 'code', FILTER_SANITIZE_STRING)),避免 XSS 或注入风险;
  • HTTPS 环境:若部署在 HTTPS 站点,务必启用 secure => true,防止 Cookie 被明文传输;
  • SameSite 策略:设置 'samesite' => 'Lax' 可平衡 CSRF 防护与跨站功能兼容性;
  • 调试技巧:使用浏览器开发者工具(Application → Cookies)实时查看 Cookie 是否写入;检查 Network 面板中响应头是否含 Set-Cookie 字段;
  • 替代方案思考:对于复杂状态管理,建议结合 Session 或前端 localStorage + 后端 API,而非过度依赖 Cookie 存储大量数据。

遵循以上规范,即可稳定、安全地通过复选框交互完成结构化数据的客户端持久化。

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

454

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

cookie
cookie

Cookie 是一种在用户计算机上存储小型文本文件的技术,用于在用户与网站进行交互时收集和存储有关用户的信息。当用户访问一个网站时,网站会将一个包含特定信息的 Cookie 文件发送到用户的浏览器,浏览器会将该 Cookie 存储在用户的计算机上。之后,当用户再次访问该网站时,浏览器会向服务器发送 Cookie,服务器可以根据 Cookie 中的信息来识别用户、跟踪用户行为等。

6498

2023.06.30

document.cookie获取不到怎么解决
document.cookie获取不到怎么解决

document.cookie获取不到的解决办法:1、浏览器的隐私设置;2、Same-origin policy;3、HTTPOnly Cookie;4、JavaScript代码错误;5、Cookie不存在或过期等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

368

2023.11.23

阻止所有cookie什么意思
阻止所有cookie什么意思

阻止所有cookie意味着在浏览器中禁止接受和存储网站发送的cookie。阻止所有cookie可能会影响许多网站的使用体验,因为许多网站使用cookie来提供个性化服务、存储用户信息或跟踪用户行为。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

444

2024.02.23

cookie与session的区别
cookie与session的区别

本专题整合了cookie与session的区别和使用方法等相关内容,阅读专题下面的文章了解更详细的内容。

97

2025.08.19

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

44

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.1万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号