0

0

JavaScript 设置 Cookie 并使用 PHP 获取的教程

心靈之曲

心靈之曲

发布时间:2025-10-21 12:43:01

|

872人浏览过

|

来源于php中文网

原创

javascript 设置 cookie 并使用 php 获取的教程

本文介绍了如何使用 JavaScript 在客户端设置 Cookie,并通过 PHP 在服务器端获取 Cookie 的值。重点讲解了 Cookie 的设置方式,以及在 PHP 中如何访问和使用 Cookie。同时,也指出了 Cookie 的生命周期和适用场景,并提供了使用 AJAX 传递 Cookie 的替代方案。

使用 JavaScript 设置 Cookie

在 Web 开发中,Cookie 是一种常用的在客户端存储少量数据的机制。JavaScript 提供了 document.cookie 属性来设置和读取 Cookie。

基本语法:

document.cookie = "cookieName=cookieValue; expires=date; path=/";
  • cookieName: Cookie 的名称。
  • cookieValue: Cookie 的值。
  • expires: Cookie 的过期时间,格式为 Day, DD Mon YYYY HH:MM:SS GMT。如果省略,Cookie 会在浏览器关闭时失效。
  • path: Cookie 的有效路径。如果省略,Cookie 只对当前页面有效。通常设置为 /,表示对整个网站有效。

示例:

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

《PHP程序设计》第二版
《PHP程序设计》第二版

本书图文并茂,详细讲解了使用LAMP(PHP)脚本语言开发动态Web程序的方法,如架设WAMP平台,安装与配置开源Moodle平台,PHP程序设计技术,开发用户注册与验证模块,架设LAMP平台。 本书适合计算机及其相关专业本、专科学生作为学习LAMP(PHP)程序设计或动态Web编程的教材使用,也适合对动态Web编程感兴趣的读者自觉使用,对LAMP(PHP)程序设计人员也具有一定的参考价值。

下载
// 设置一个名为 'username' 的 Cookie,值为 'JohnDoe',有效期为 7 天
let now = new Date();
let time = now.getTime();
let expireTime = time + 7*24*60*60*1000;
now.setTime(expireTime);

document.cookie = "username=JohnDoe;expires=" + now.toUTCString() + ";path=/";

// 设置一个名为 'testing' 的 Cookie,其值来自耗时操作
async function setCookie() {
  // 模拟一个耗时操作,例如从第三方 API 获取数据
  const data = await new Promise(resolve => setTimeout(() => resolve("Data from API"), 5000));
  document.cookie = "testing=" + data + ";path=/";
  console.log("Cookie 'testing' set with value:", data);
}

setCookie();

注意事项:

  • Cookie 的值需要进行 URL 编码,以避免特殊字符引起的问题。可以使用 encodeURIComponent() 函数进行编码。
  • Cookie 的大小有限制,通常为 4KB。

使用 PHP 获取 Cookie

PHP 提供了一个超全局变量 $_COOKIE 来访问客户端设置的 Cookie。

基本语法:

示例:

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

Testing Cookie Value: " . htmlspecialchars($testingValue);
  } else {
    echo "
Testing Cookie not set."; } ?>

注意事项:

  • 在访问 Cookie 之前,应该使用 isset() 函数检查 Cookie 是否存在,以避免出现错误。
  • 为了安全起见,应该对 Cookie 的值进行适当的过滤和转义,以防止 XSS 攻击。可以使用 htmlspecialchars() 函数进行转义。

Cookie 的生命周期和适用场景

Cookie 的生命周期由 expires 属性决定。如果省略 expires 属性,Cookie 会在浏览器关闭时失效,称为会话 Cookie。如果设置了 expires 属性,Cookie 会在指定的过期时间后失效,称为持久 Cookie。

Cookie 适用于存储少量、非敏感的用户数据,例如:

  • 用户偏好设置
  • 登录状态
  • 购物车信息

使用 AJAX 传递 Cookie

由于 Cookie 在设置后需要重新加载页面才能在 PHP 中访问,如果不想重新加载页面,可以使用 AJAX 将 Cookie 的值传递给 PHP。

示例:

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

// JavaScript (假设已设置 Cookie 'testing')
async function sendCookieToPHP() {
  const testingValue = document.cookie.replace(/(?:(?:^|.*;\s*)testing\s*\=\s*([^;]*).*$)|^.*$/, "$1");

  const response = await fetch('process_cookie.php', {
    method: 'POST',
    headers: {
      'Content-Type': 'application/x-www-form-urlencoded',
    },
    body: `testing=${encodeURIComponent(testingValue)}`
  });

  const result = await response.text();
  console.log(result); // 显示 PHP 的响应
}

sendCookieToPHP();

总结:

本文介绍了如何使用 JavaScript 设置 Cookie,并通过 PHP 获取 Cookie 的值。通过理解 Cookie 的设置方式、生命周期和适用场景,可以更好地利用 Cookie 来实现 Web 应用的功能。同时,也介绍了使用 AJAX 传递 Cookie 的替代方案,以满足不同的需求。记住要对 Cookie 的值进行适当的过滤和转义,以确保 Web 应用的安全性。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

159

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

160

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

117

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

235

2024.09.24

cookie
cookie

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

6428

2023.06.30

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

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

347

2023.11.23

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

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

414

2024.02.23

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

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

93

2025.08.19

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

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

共137课时 | 10.2万人学习

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

共6课时 | 11.2万人学习

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

共13课时 | 0.9万人学习

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

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