JavaScript Cookie

什么是Cookie?

Cookie是一个小型文本文件,可让您在用户计算机上存储少量数据(近4KB)。

Web服务器将网页发送到浏览器后,连接将关闭,并且服务器会忘记有关用户的所有信息。

发明了Cookies来解决“如何记住有关用户的信息”的问题。

Cookies可用于跟踪信息,例如用户喜好,当用户下次访问网站时,网站可以检索该信息以个性化页面。

Cookies以“名称=值”对的形式保存,例如:

username = Seagull

当浏览器从服务器请求网页时,属于该页面的cookie被添加到请求中。这样,服务器将获得必要的数据以“记住”有关用户的信息。

注意:请勿在Cookie中存储敏感数据,例如密码或信用卡信息,因为恶意用户可能会操纵它们。

使用JavaScript创建Cookie

在JavaScript中,您可以使用document.cookie属性创建,读取和删除Cookie 。

可以这样创建一个cookie:

  document.cookie = "username=Seagull";

您还可以添加到期日期(以UTC时间为单位)。默认情况下,关闭浏览器时会删除cookie:

  document.cookie = "username=Seagull; expires=Mon, 25 Mar 2019 12:00:00 UTC";

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

  document.cookie = "username=Seagull; expires=Mon, 25 Mar 2019 12:00:00 UTC; path=/";

使用JavaScript读取Cookie

在JavaScript中,可以这样读取cookie:

  var x = document.cookie;

读取cookie稍微复杂一点,因为该document.cookie属性仅返回一个包含分号和所有cookie的空格分隔列表的字符串(例如,名称=值对,例如cookie1 = value; cookie2 = value; cookie3 = value)。为了从此列表中获取单个cookie,您需要使用split()方法将其分成单个name = value对,并搜索特定名称。

此字符串不包含属性,如expires,path,domain,等,可能已经为Cookie集。

使用JavaScript更改Cookie

改变或修改一个cookie的唯一方法是创建一个具有相同的另一种饼干name和path为现有的。

  document.cookie = "username=Ankit; expires=Mon, 25 Mar 2019 12:00:00 UTC; path=/";

注意:创建具有相同name但不同的cookie path不会更改现有的cookie,而是会添加一个额外的cookie。

使用JavaScript删除Cookie

删除Cookie非常容易。删除Cookie:

  • 只需再次使用相同的设置name,指定一个空值

  • 或将expires参数设置为经过的日期

  document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/";

请记住,如果您path为cookie 指定了或其他属性,则在删除它时还需要包括它们。

JavaScript Cookie示例

在下面的示例中,我们将创建一个存储用户名的cookie。

用户首次访问该网页时,将要求他/她填写其姓名。然后将该名称存储在cookie中。

下次用户访问同一页面时,他/她将获得存储在cookie中的值。

对于示例,我们将创建2个JavaScript函数:

  • 设置cookie值的功能

  • 获取Cookie值的函数

储存cookie

首先,我们创建一个将访问者的姓名存储在cookie变量中的函数。

function setCookie(cname, cvalue{
  var now = new Date();
  now.setMonth(now.getMonth() + 1);
  var expires = "expires="+ now.toUTCString();
  document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
}

功能说明:

上面函数的参数是cookie的名称(cname)和cookie的值(cvalue)。

该函数通过将cookie名称,cookie值和expires字符串(1个月)加在一起来设置cookie。

读取cookie

然后,我们创建一个显示指定cookie值的函数。

function getCookie(cname{
  var allcookies = document.cookie;
  cookieArr = allcookies.split(';');

  for(var i = 0; i < cookieArr.length; i++) {
     var cookiePair = cookieArr[i].split("=");
     if(cname == cookiePair[0].trim()) {
        document.write ("Key is: " + cookiePair[0] + " and Value is: " + cookiePair[1]);
     }
  }
}

函数说明:

此函数将cookie名称作为参数(cname)。

获取所有cookie(allcookies = document.cookie)。

将分号上的document.cookie拆分为名为cookieArr的数组(cookieArr = allcookies.split(';'))。

遍历cookieArr数组(i = 0; i <cookieArr.length; i ++),并读出每个值(cookiePair = cookieArr [i])。

如果找到了cookie(cname == cookiePair [0]),则写入cookie的键和值(cookiePair [0],cookiePair [1])。

合在一起

function setCookie(cname, cvalue{
  var now = new Date();
  now.setMonth(now.getMonth() + 1);
  var expires = "expires="+ now.toUTCString();
  document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
}

function getCookie(cname{
  var allcookies = document.cookie;
  cookieArr = allcookies.split(';');
  for(var i = 0; i < cookieArr.length; i++) {
     var cookiePair = cookieArr[i].split("=");
     if(cname == cookiePair[0].trim()) {
           document.write ("Key is: " + cookiePair[0] + " and Value is: " + cookiePair[1]);
     }
  }
}

Cookies属性

Cookies是具有5个属性的纯文本数据记录:

属性 描述
Name=Value Cookies以键值对的形式设置和检索
Expires Cookie到期的日期。如果为空,则cookie将在访问者退出浏览器时过期
Domain 您网站的域名
Path 设置cookie的目录或网页的路径。如果要从任何目录或页面检索cookie,则该字段可以为空白
Secure 如果此字段包含单词“ secure”,则只能使用安全服务器检索cookie。如果此字段为空,则不存在此类限制
评论
列表