整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

JavaScript编程 Cookie

ookie 用于存储 web 页面的用户信息。


什么是 Cookie?

Cookie 是一些数据, 存储于你电脑上的文本文件中。

当 web 服务器向浏览器发送 web 页面时,在连接关闭后,服务端不会记录用户的信息。

Cookie 的作用就是用于解决 "如何记录客户端的用户信息":

  • 当用户访问 web 页面时,他的名字可以记录在 cookie 中。

  • 在用户下一次访问该页面时,可以在 cookie 中读取用户访问记录。

Cookie 以名/值对形式存储,如下所示:

username=John Doe

当浏览器从服务器上请求 web 页面时, 属于该页面的 cookie 会被添加到该请求中。服务端通过这种方式来获取用户的信息。


使用 JavaScript 创建Cookie

JavaScript 可以使用 document.cookie 属性来创建 、读取、及删除 cookie。

JavaScript 中,创建 cookie 如下所示:

document.cookie="username=John Doe";

您还可以为 cookie 添加一个过期时间(以 UTC 或 GMT 时间)。默认情况下,cookie 在浏览器关闭时删除:

document.cookie="username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT";

您可以使用 path 参数告诉浏览器 cookie 的路径。默认情况下,cookie 属于当前页面。

document.cookie="username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/";


使用 JavaScript 读取 Cookie

在 JavaScript 中, 可以使用以下代码来读取 cookie:

var x = document.cookie;


使用 JavaScript 修改 Cookie

在 JavaScript 中,修改 cookie 类似于创建 cookie,如下所示:

document.cookie="username=John Smith; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/";

旧的 cookie 将被覆盖。


使用 JavaScript 删除 Cookie

删除 cookie 非常简单。您只需要设置 expires 参数为以前的时间即可,如下所示,设置为 Thu, 01 Jan 1970 00:00:00 GMT:

document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT";

注意,当您删除时不必指定 cookie 的值。


Cookie 字符串

document.cookie 属性看起来像一个普通的文本字符串,其实它不是。

即使您在 document.cookie 中写入一个完整的 cookie 字符串, 当您重新读取该 cookie 信息时,cookie 信息是以名/值对的形式展示的。

如果您设置了新的 cookie,旧的 cookie 不会被覆盖。 新 cookie 将添加到 document.cookie 中,所以如果您重新读取document.cookie,您将获得如下所示的数据:

cookie1=value; cookie2=value;

显示所有 Cookie 创建 Cookie 1 创建 Cookie 2 删除 Cookie 1 删除 Cookie 2

如果您需要查找一个指定 cookie 值,您必须创建一个JavaScript 函数在 cookie 字符串中查找 cookie 值。


JavaScript Cookie 实例

在以下实例中,我们将创建 cookie 来存储访问者名称。

首先,访问者访问 web 页面, 他将被要求填写自己的名字。该名字会存储在 cookie 中。

访问者下一次访问页面时,他会看到一个欢迎的消息。

在这个实例中我们会创建 3 个 JavaScript 函数:

  1. 设置 cookie 值的函数

  2. 获取 cookie 值的函数

  3. 检测 cookie 值的函数


设置 cookie 值的函数

首先,我们创建一个函数用于存储访问者的名字:

function setCookie(cname,cvalue,exdays){

函数解析:

以上的函数参数中,cookie 的名称为 cname,cookie 的值为 cvalue,并设置了 cookie 的过期时间 expires。

该函数设置了 cookie 名、cookie 值、cookie过期时间。


获取 cookie 值的函数

然后,我们创建一个函数用户返回指定 cookie 的值:

function getCookie(cname){

函数解析:

cookie 名的参数为 cname。

创建一个文本变量用于检索指定 cookie :cname + "="。

使用分号来分割 document.cookie 字符串,并将分割后的字符串数组赋值给 ca (ca = document.cookie.split(';'))。

循环 ca 数组 (i=0;i<ca.length;i++),然后读取数组中的每个值,并去除前后空格 (c=ca[i].trim())。

如果找到 cookie(c.indexOf(name) == 0),返回 cookie 的值 (c.substring(name.length,c.length)。

如果没有找到 cookie, 返回 ""。


检测 cookie 值的函数

最后,我们可以创建一个检测 cookie 是否创建的函数。

如果设置了 cookie,将显示一个问候信息。

如果没有设置 cookie,将会显示一个弹窗用于询问访问者的名字,并调用 setCookie 函数将访问者的名字存储 365 天:

function checkCookie(){

完整实例

实例

functionsetCookie(cname,cvalue,exdays){vard = newDate(); d.setTime(d.getTime()+(exdays*24*60*60*1000)); varexpires = "expires="+d.toGMTString(); document.cookie = cname + "=" + cvalue + "; " + expires;}functiongetCookie(cname){varname = cname + "="; varca = document.cookie.split(';'); for(vari=0; i<ca.length; i++){varc = ca[i].trim(); if(c.indexOf(name)==0)returnc.substring(name.length,c.length); }return"";}functioncheckCookie(){varuser=getCookie("username"); if(user!=""){alert("Welcome again " + user); }else{user = prompt("Please enter your name:",""); if(user!="" && user!=null){setCookie("username",user,365); }}}

以下实例在页面载入时执行 checkCookie() 函数。

document.cookie 将以字符串的方式返回所有的 cookie,类型格式: cookie1=value; cookie2=value; cookie3=value;

在前端开发领域,数据持久化是一个常见的需求,特别是在无状态的 HTTP 协议下,我们需要一种机制来保存用户会话信息或其他需要跨页面或跨请求保留的数据。Cookie 就是其中一种广泛使用的解决方案,它允许我们存储少量的信息在用户的浏览器中。本文旨在深入探讨 JavaScript 中操作 Cookie 的方法,包括其基本原理、常见用法、实战案例以及一些优化技巧。

技术概述

定义

Cookie 是一种在客户端存储数据的小型文本文件,由服务器通过 HTTP 响应头 Set-Cookie 发送给浏览器,并由浏览器保存在本地。当浏览器再次访问同一域名下的网页时,会自动将之前接收到的 Cookie 包含在 HTTP 请求头中发送回服务器。

核心特性与优势

  • 持久性:Cookie 可以长期存储在客户端,直到过期时间到达或被显式删除。
  • 易用性:JavaScript 提供了直接读取和修改 Cookie 的能力,通过简单的字符串操作即可实现。
  • 安全性:通过设置 securehttpOnly 属性,可以增强 Cookie 的安全性和防止跨站脚本攻击(XSS)。

示例代码

// 设置一个名为 "user" 的 Cookie
function setCookie(name, value, days) {
  var expires = "";
  if (days) {
    var date = new Date();
    date.setTime(date.getTime() + (days*24*60*60*1000));
    expires = "; expires=" + date.toUTCString();
  }
  document.cookie = name + "=" + (value || "")  + expires + "; path=/";
}

// 获取一个名为 "user" 的 Cookie 的值
function getCookie(name) {
  var nameEQ = name + "=";
  var ca = document.cookie.split(';');
  for(var i=0;i < ca.length;i++) {
    var c = ca[i];
    while (c.charAt(0)==' ') c = c.substring(1,c.length);
    if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length,c.length);
  }
  return null;
}

技术细节

Cookie 存储的数据量有限,通常不超过 4KB,并且每个域名下可以存储的 Cookie 数量也有限制。因此,在设计系统时需要考虑这些限制,避免过度使用 Cookie 导致数据溢出或性能下降。

实战应用

场景:用户登录状态保持

当用户登录网站后,我们可以设置一个包含用户 ID 或其他标识信息的 Cookie,这样在后续的页面请求中,服务器可以根据这个 Cookie 确定用户的身份,从而无需用户重新登录。

示例代码

// 登录成功后设置 Cookie
setCookie('userId', '12345', 30); // 保存30天

// 在其他页面读取用户 ID
var userId = getCookie('userId');
if (userId) {
  console.log('Welcome back, user with ID: ', userId);
} else {
  console.log('User is not logged in.');
}

优化与改进

分析潜在问题

Cookie 的主要问题是存储容量有限,这可能在多应用共享 Cookie 时成为瓶颈。此外,Cookie 数据会被包含在每次请求中,这会增加网络流量,影响性能。

解决方案

  • 使用更高效的数据压缩算法来减少 Cookie 的大小。
  • 考虑使用 SessionStorage 或 LocalStorage 这些 Web Storage API 来替代部分非必需的 Cookie。
  • 对于不经常变化的数据,可以考虑使用 HTTP 缓存机制。

常见问题

问题:如何删除一个 Cookie?

由于 Cookie 的本质是在 HTTP 响应中设置的,因此删除一个 Cookie 实际上是设置其过期时间为过去的一个时间点。

示例代码

// 删除一个名为 "userId" 的 Cookie
function deleteCookie(name) {
  document.cookie = name+'=; Max-Age=-99999999;';
}

总结与展望

Cookie 作为前端数据持久化的一种手段,虽然有其局限性,但在许多场景下仍然发挥着重要作用。随着 Web 技术的发展,新的存储方式如 Web Storage API 已经提供了更强大的功能,但 Cookie 以其轻量级和普遍兼容性仍然不可替代。掌握 Cookie 的使用和优化策略,对于提高前端应用的用户体验和性能具有重要意义。未来,我们期待看到更多的技术创新,使得数据管理和用户隐私保护更加高效和安全。

ookie可以在用户的浏览器中保存一些信息,比如用户的用户名,密码等。今天这篇博文就说一说利用用原生的javascript代码来设置cookie,读取cookie,以及删除cookie的方法。

什么是cookie ?

cookie:是记录在用户浏览器中的信息,通常情况下是以“键/值”的形式进行存储的,可设置过期的时间.

如以下格式

name=mochu

name:为键名,也就是cookie记录的变量名

mochu:为cookie记录的值

当web页面向服务器发出请求时,属于此页面的所有cookie信息,也一并上传到服务器,服务器端可以通过对cookie的识别,来辨别出页面的来源或是用户的身份。

js创建 cookie 的方法

js中可以通过 document.cookie 来创建 cookie

方法1:

可以直接创建一个 cookie

document.cookie = "Name=mochu";

方法2:

创建一个带有过期时间的 cookie ,这里用的是 GMT 时间

document.cookie = "Name=mochu ; expires = Sat, 10 Aug 2019 08:55:38 GMT";

注意:如果不设置过期时间,则在浏览器关闭时,cookie自动过期或删除

方法3:

设置cookie的有效果路径,默认情况下,cookie只对当前页面有效果

path=/:表示cookie对web页面所属网站的全部页面有效果,你也可以自定义其它路径

document.cookie = "Name=mochu ; expires = Sat, 10 Aug 2019 08:55:38 GMT ;path=/";

自定义JS设置 cookie 的函数

函数代码

function setCookie(name, value, time='',path='') {
 if(time && path){
 var strsec = time * 1000;
 var exp = new Date();
 exp.setTime(exp.getTime() + strsec * 1);
 document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString() + ";path="+path;
 }else if(time){
 var strsec = time * 1000;
 var exp = new Date();
 exp.setTime(exp.getTime() + strsec * 1);
 document.cookie = name + "=" + escape(value) + ";expires=" + exp.toGMTString();
 }else if(path){
 document.cookie = name + "=" + escape(value) + ";path="+path;
 }else{
 document.cookie = name + "=" + escape(value);
 }
}

函数调用

setCookie("Name", "mochu", 20);

参数:cookie名称,cookie值,过期时间(秒为单为),路径

js读取 cookie 的方法

js 读取cookie的方法也是要用到 document.cookie

如下代码:

var x = document.cookie;

document.cookie,会以字符串的形式反回所有的cookie

例:

setCookie("Name", "mochu",20,'/');
setCookie("pass", "123", 20, '/');
var x = document.cookie;
console.log(x);

打印结果:

Name=mochu; pass=123

自定义js获取 cookie 的函数

document.cookie 获取到的 cookie 都是字符串的形式,我们可以对其获取的结果进行加工,来输出指定的 cookie

function getCookie(name) {
 var arr, reg = new RegExp("(^| )" + name + "=([^;]*)(;|$)");
 if (arr = document.cookie.match(reg)){
 return unescape(arr[2]);
 }else{
 return null;
 }
}

调用方法

console.log(getCookie('Name'));

打印结果:

mochu

js删除 cookie 的方法

js 删除cookie 的操作非常简单,只要将 cookie 的过期时候设置成比当前时间小就可以了

自定义函数代码:

function delCookie('Name'); {
 var exp = new Date();
 exp.setTime(exp.getTime() - 1);
 // 这里需要判断一下cookie是否存在
 var c = getCookie(name);
 if (c != null){
 document.cookie = name + "=" + c + ";expires=" + exp.toGMTString();
 }
}

调用方式:

delCookie('Name');

javascript 操作 cookie 代码整理: