在编程领域,Cookie 代表一种小型的文本文件,可以让开发人员在用户计算机上存储少量的数据(大约 4kb),来记录用户的某些信息,例如用户身份、喜好等,当用户下次访问网站时,网站可以通过检索这些信息来为用户展示个性化页面。另外,一些电商网站的购物车也用到了 Cookie 技术。

在 HTTPS 协议还未诞生之前,Web 浏览器和服务器之间需要通过 HTTP 协议进行通信,HTTP 协议是一种无状态协议,当服务器与浏览器之间完成一次交互(浏览器向服务器发送请求,服务器做出响应)后,链接会被关闭,服务器就会忘记浏览器的一切。Cookie 就是为了让服务器能够记住浏览器而发明的。

当使用浏览器访问某个页面时,可以将一些浏览器的信息会存储在 Cookie 中,浏览器每次向服务器发送请求时,Cookie 会作为请求的一部分一同发送给服务器,这样服务器就能通过 Cookie 中的信息来记住浏览器了。

提示:Cookie 由若干个键/值对组成(例如key1=value1;key2=value2),一个 Cookie 最大可以存储 4kb 的数据,超过长度的 Cookie 将被忽略。您也可以在浏览器端禁用 Cookie,这样一些借助 Cookie 才能完成的操作将无法进行。另外,不要在 Cookie 中存储账号、密码等敏感信息。

Cookie 最初是为 PHP、ASP 等服务器端脚本语言设计的,但是我们也可以使用 JavaScript 来操作,只是操作起来比较复杂,下面就来简单介绍一下如何使用 JavaScript 来操作 Cookie。

JS 设置 Cookie

在 JavaScript 中,您可以通过document.cookie属性来创建、读取、修改和删除 Cookie 信息。

创建(设置)新的 Cookie 信息,需要以name=value形式的字符串来定义新的 Cookie 信息,如下例所示:

document.cookie = "url=http://c.biancheng.net/";

Cookie 数据中不能包含分号、逗号或空格,因此在将数据存储到 Cookie 之前,可以使用 JavaScript 内置的 encodeURIComponent() 函数对数据进行编码。在读取 Cookie 时,使用对应的 decodeURIComponent() 函数来解析 Cookie 数据,如下例所示:

document.cookie = "url=" + encodeURIComponent("http://c.biancheng.net/");

注意:运行上面的代码,您会发现 Cookie 并没有创建,这是因为 Cookie 是用来与服务器进行交互的,所以要成功创建 Cookie 需要借助服务器环境。您可以阅读《PHP开发环境》一节,来搭建一个简单的开发环境,并将我们定义的 HTML 文件移动到应用目录(默认为安装目录的 apache2/htdocs 目录下)中,然后访问我们的 HTML 文件。

Cookie 并不会一直存在,默认情况下,Cookie 的生命周期就是浏览器的会话周期,即用户关闭浏览器后,Cookie 就会失效。 如果想要延长 Cookie 的生命周期,您可以使用 max-age 属性来指定 Cookie 可以存在的时间(单位为秒),默认为 -1,即关闭浏览器后失效。

如果将 max-age 设置为一个负数,则表示该 Cookie 为临时 Cookie,关闭浏览器后就会失效。如果设置为 0,则表示删除该 Cookie。若要将 Cookie 的生命周期设置为 30 天的话,则可以像下面这样:

document.cookie = "url=http://c.biancheng.net/; max-age=" + 30*24*60*60;

此外,您也可以使用 expires 属性来指定 Cookie 失效的具体日期(GMT/UTC 格式),如下所示:

document.cookie = "url=http://c.biancheng.net/; expires=Sun, 31 Dec 2017 12:00:00 UTC;";

提示:通过为 Cookie 设置生命周期,不仅可以延长 Cookie 存在的时间,还可以让 Cookie 提前失效。

默认情况下,Cookie 可用于同一域名下的所有网页,但如果您为 Cookie 设置了 path 属性,那么 Cookie 就只能在该域名指定路径下的网页中使用,例如网站的域名为 c.biancheng.net,若 path 属性设置为/,则表示 Cookie 可在域名下的所有网页中使用,若 path 属性设置为/javascript/,则 Cookie 只可在 http://c.biancheng.net/javascript/ 下的网页中使用,示例代码如下:

document.cookie = "url=http://c.biancheng.net/; path=/";

如果您希望 Cookie 可以在指定域名下的子域名中使用,则可以通过 domain 属性来设置,默认情况下,Cookie 仅可在设置它的域名下使用,示例代码如下:

document.cookie = "url=http://c.biancheng.net/; path=/; domain=.biancheng.net";

若将 domain 属性设置为.biancheng.net,则表示 Cookie 可在所有以biancheng.net结尾的域名下使用,注意,domain 属性值的第一个字符.不能省略。

此外,Cookie 中还有一个属性 secure,该属性只有一个属性名,没有属性值,如果设置了该属性,则表示 Cookie 将仅通过 HTTPS 协议传输,示例代码如下:

document.cookie = "url=http://c.biancheng.net/; path=/; domain=.biancheng.net; secure";

为了方便设置 Cookie,我们可以定义一个函数,如下所示:

/**
* 添加 Cookie
* @param {[string]} name [Cookie 的名称]
* @param {[string]} value [Cookie 的值]
* @param {[number]} daysToLive [Cookie 的过期时间]
*/
function setCookie(name, value, daysToLive) {
// 对 cookie 值进行编码以转义其中的分号、逗号和空格
var cookie = name + "=" + encodeURIComponent(value);if(typeof daysToLive === "number") {
/* 设置 max-age 属性 */
cookie += "; max-age=" + (daysToLive*24*60*60);
}
document.cookie = cookie;
}

JS 获取 Cookie

读取(获取) Cookie 同样使用document.cookie即可,该属性会返回一个字符串,字符串中包含除 max-age、expires、path 和 domain 等属性之外的所有 Cookie 信息,例如url=http://c.biancheng.net/; course=JavaScript。为了获取单个 Cookie 的值,我们可以通过 split() 函数将包含 Cookie 信息的字符串拆分为数组,然后再获取某个 Cookie 的值,示例代码如下:

document.cookie = "url=http://c.biancheng.net/; max-age=" + 30*24*60*60;
document.cookie = "course=JavaScript";
document.cookie = "title=cookie";function getCookie(name) {
// 拆分 cookie 字符串
var cookieArr = document.cookie.split(";");// 循环遍历数组元素
for(var i = 0; i < cookieArr.length; i++) {
var cookiePair = cookieArr[i].split("=");/* 删除 cookie 名称开头的空白并将其与给定字符串进行比较 */
if(name == cookiePair[0].trim()) {
// 解码cookie值并返回
return decodeURIComponent(cookiePair[1]);
}
}
// 如果未找到,则返回null
return null;
}
document.write("url = " + getCookie("url") + "<br>"); // 输出:url = http://c.biancheng.net/
document.write("course = " + getCookie("course") + "<br>"); // 输出:course = JavaScript
document.write("title = " + getCookie("title")); // 输出:title = cookie

JS 修改或更新 Cookie 的值

修改或更新 Cookie 值的唯一方法就是创建一个同名的 Cookie,来替换要修改的 Cookie。注意,若要修改的 Cookie 定义了 path 属性,在修改该属性时也要定义相同的 path 属性,否则会创建一个新的 Cookie。示例代码如下:

  1. // 创建一个 Cookie
  2. document.cookie = "url=http://c.biancheng.net/; path=/; max-age=" + 30*24*60*60;
  3. // 修改这个 Cookie
  4. document.cookie = "url=http://c.biancheng.net/javascript/; path=/; max-age=" + 365*24*60*60;

提示:若 path 属性为/,在修改时也可以省略 path 属性。

JS 删除 Cookie

删除 Cookie 与修改 Cookie 类似,只需要重新将 Cookie 的值设置为空,并将 expires 属性设置为一个过去的日期即可,如下例所示:

纯文本复制
  1. // 创建一个 Cookie
  2. document.cookie = "url=http://c.biancheng.net/; path=/; max-age=" + 30*24*60*60;
  3. // 删除这个 Cookie
  4. document.cookie = "url=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;";

另外,也可通过将 max-age 属性设置为 0 来删除 Cookie。

JS cookie的设置、获取和删除(非常详细)相关推荐

  1. Cookie的设置获取和删除

    关于Cookie操作的实验,包括设置,获取和删除. 设置Cookie name[必选] value[必选] expiredays[必选] setCookie getCookie 操作Cookie GE ...

  2. 前端cookie的设置获取删除

    前端cookie的设置获取删除 /* 我们有过这样的经历,当我们登录一个网站时候,网站会提示我们需不需要记住账号和密码一般来说,当我们登录一个网站时,后台会返回一个token字符串作为用户的登录标识, ...

  3. 封装的cookie存储、获取、删除方法

    2019独角兽企业重金招聘Python工程师标准>>> 封装的cookie存储.获取.删除方法 1.设置cookie function setCookie(key, value, t ...

  4. js,jq设置获取属性,样式

    js设置获取属性:设置属性-element.setAttribute("属性名称","属性值"):获取属性-element.getAttribute(" ...

  5. 原生js本地存储、获取、删除、清空

    利用原生js手撕本地存储实现 存储.获取.删除.清空功能. 代码如下: <!DOCTYPE html> <html><head><meta charset=& ...

  6. 37.Django中设置获取和删除cookie

    引言--我们都知道HTTP(超文本传输协议)是一个无状态的协议. 那么客户端和服务器都是怎么记录登录的状态的呢--也就是怎么维持登录的呢? (比如:你在浏览器中登录过了爱奇艺账号,哪怕你网页关闭了,只 ...

  7. vue的cookies:vue-cookies 设置,获取及删除指定的cookies

    安装: npm install vue-cookies --save 引用 main.js中设置 // vue-cookies配置 import cookies from 'vue-cookies' ...

  8. JS设置,获取,删除cookie

    JS设置,获取,删除cookie 由于chrome等浏览器存在samesite安全措施,导致传统http页面后端无法设置cookie到前端,所以考虑在返回值中添加cookie值,使用前端js进行coo ...

  9. js设置获取删除cookie

    /* cookie 会有一个过期时间,如果不设置过期时间那么关闭页面就会消失,如果想要删除这个cookie的话就要设置一个过期时间,存储大小只有4kb左右设置无过期时间: document.cooki ...

最新文章

  1. caffe实现多任务学习
  2. Construct Binary Tree from Inorder and Postorder Traversal
  3. echarts label加边框_关于echarts的lines中的label的设置 -问答-阿里云开发者社区-阿里云...
  4. AI 中介上岗,人工智能版《安家》?
  5. matlab 符号表达式 系数 小数,matlab符号表达式系数
  6. 语言程序推箱子课设报告_学完C语言,可以去哪些应用领域工作?
  7. 【笔试/面试】—— 二叉树的最远距离
  8. php选课系统参考文献,学生选课系统参考文献
  9. jdk版本导致的DB2异常:必需的字符转换器不可用。ERRORCODE=-4220, SQLSTATE=null
  10. Notepad++--常用的插件
  11. 《zw版·Halcon-delphi系列原创教程》 2d照片-3d逆向建模脚本
  12. 浏览器事件模型捕获、冒泡
  13. python概率分布拟合_用Python实现概率分布
  14. windows nginx出现 was not signaled for 5s
  15. C++ GUI Programming with Qt4 Second Edition 之 附录A.2 Windows系统Qt的安装
  16. Linux 命令 ps
  17. 1046 mysql_MYSQL 1046 错误求助:
  18. 网关(Gateway)
  19. python自学笔记11之文件(文本、CSV)
  20. 美团-轻食餐饮发展指南

热门文章

  1. mysql mvvc原理_Mysql MVVC笔记
  2. python如何找对象_【从Python开始学编程】帮Python找对象
  3. Windows下Nginx和php-cgi的bat批处理快速启动方法
  4. Python中文编码,python注释方式
  5. Spring Boot(Cloud) 优雅停机
  6. ActiveReports.NET 16.2RPX 部分报告的完全支持
  7. 苹果电脑装windows 7成功记 MacBook Pro
  8. 最近的项目中用到读卡器,用的华视身份证阅读器,附上SDK使用手册
  9. 泛企业搜索PK互联网搜索
  10. 水产养殖微滤机滤网 微滤机滤网