详解Document.Cookie

详解Document.Cookie转自:https://www.jb51.net/article/77009.htm具体来说cookie机制采用的是在客户端保持状态的方案,而session机制采用的是在服务器端保持状态的方案。同时

大家好,又见面了,我是你们的朋友全栈君。

转自:https://www.jb51.net/article/77009.htm

具体来说cookie机制采用的是在客户端保持状态的方案,而session机制采用的是在服务器端保持状态的方案。

同时我们也看到,由于采用服务器端保持状态的方案在客户端也需要保存一个标识,所以session机制可能需要借助于cookie机制来达到保存标识的目的,但实际上它还有其他选择。

设置cookie

    每个cookie都是一个名/值对,可以把下面这样一个字符串赋值给document.cookie:

 1 document.cookie=”userId=828″; 

    如果要一次存储多个名/值对,可以使用分号加空格(; )隔开,例如:

 1 document.cookie=”userId=828; userName=hulk”; 

在cookie的名或值中不能使用分号(;)、逗号(,)、等号(=)以及空格。在cookie的名中做到这点很容易,但要保存的值是不确定的。如何来存储这些值呢?方法是用escape()函数进行编码,它能将一些特殊符号使用十六进制表示,例如空格将会编码为“20%”,从而可以存储于cookie值中,而且使用此种方案还可以避免中文乱码的出现。例如:

 1 document.cookie=”str=”+escape(”I love ajax”); 

    相当于:

 1 document.cookie=”str=I%20love%20ajax”; 

当使用escape()编码后,在取出值以后需要使用unescape()进行解码才能得到原来的cookie值,这在前面已经介绍过。
    尽管document.cookie看上去就像一个属性,可以赋不同的值。但它和一般的属性不一样,改变 它的赋值并不意味着丢失原来的值,例如连续执行下面两条语句:

 1 document.cookie=”userId=828″; 2 document.cookie=”userName=hulk”; 

 

这时浏览器将维护两个cookie,分别是userId和userName,因此给document.cookie赋值更像执行类似这样的语句:

 1 document.addCookie(”userId=828″); 2 document.addCookie(”userName=hulk”); 

 

    事实上,浏览器就是按照这样的方式来设置cookie的,如果要改变一个cookie的值,只需重新赋值,例如:

 1 document.cookie=”userId=929″; 

这样就将名为userId的cookie值设置为了929。

    获取cookie的值

    下面介绍如何获取cookie的值。cookie的值可以由document.cookie直接获得:

 1 var strCookie=document.cookie; 

这将获得以分号隔开的多个名/值对所组成的字符串,这些名/值对包括了该域名下的所有cookie。例如:、

1 <script language="JavaScript" type="text/javascript">
2 <!--
3 document.cookie="userId=828";
4 document.cookie="userName=hulk";
5 var strCookie=document.cookie;
6 alert(strCookie);
7 //-->
8 </script>

 

   图7.1显示了输出的cookie值。由此可见,只能够一次获取所有的cookie值,而不能指定cookie名称来获得指定的值,这正是处理 cookie值最麻烦的一部分。用户必须自己分析这个字符串,来获取指定的cookie值,例如,要获取userId的值,可以这样实现:

 1 <script language="JavaScript" type="text/javascript">
 2  <!--
 3  //设置两个cookie
 4  document.cookie="userId=828";
 5  document.cookie="userName=hulk";
 6  //获取cookie字符串
 7  var strCookie=document.cookie;
 8  //将多cookie切割为多个名/值对
 9  var arrCookie=strCookie.split("; ");
10  var userId;
11  //遍历cookie数组,处理每个cookie对
12  for(var i=0;i<arrCookie.length;i++){
13  var arr=arrCookie[i].split("=");
14  //找到名称为userId的cookie,并返回它的值
15  if("userId"==arr[0]){
16  userId=arr[1];
17  break;
18  }
19  }
20  alert(userId);
21  //-->
22  </script>

这样就得到了单个cookie的值用类似的方法,可以获取一个或多个cookie的值,其主要的技巧仍然是字符串和数组的相关操作。

    给cookie设置终止日期

    到现在为止,所有的cookie都是单会话cookie,即浏览器关闭后这些cookie将会丢失,事实上这些cookie仅仅是存储在内存中,而没有建立相应的硬盘文件。

    在实际开发中,cookie常常需要长期保存,例如保存用户登录的状态。这可以用下面的选项来实现

 1 document.cookie=”userId=828; expires=GMT_String”; 

其中GMT_String是以GMT格式表示的时间字符串,

这条语句就是将userId这个cookie设置为GMT_String表示的过期时间,

超过这个时间,cookie将消失,不可访问。

例如:如果要将cookie设置为10天后过期,可以这样实现:

 1 <script language="JavaScript" type="text/javascript">
 2  <!--
 3  //获取当前时间
 4  var date=new Date();
 5  var expireDays=10;
 6  //将date设置为10天以后的时间
 7  date.setTime(date.getTime()+expireDays*24*3600*1000);
 8  //将userId和userName两个cookie设置为10天后过期
 9  document.cookie="userId=828; userName=hulk; expire="+date.toGMTString();
10  //-->
11  </script>
12  
13  删除cookie
14  
15  为了删除一个cookie,可以将其过期时间设定为一个过去的时间,例如:
16  
17  <script language="JavaScript" type="text/javascript">
18  <!--
19  //获取当前时间
20  var date=new Date();
21  //将date设置为过去的时间
22  date.setTime(date.getTime()-10000);
23  //将userId这个cookie删除
24  document.cookie="userId=828; expire="+date.toGMTString();
25  //-->
26  </script>

 

Jquery Cookie的操作参数:

创建一个会话cookie:

 1 <script language="JavaScript" type="text/javascript">
 2 <!--
 3 //获取当前时间
 4 var date=new Date();
 5 var expireDays=10;
 6 //将date设置为10天以后的时间
 7 date.setTime(date.getTime()+expireDays*24*3600*1000);
 8 //将userId和userName两个cookie设置为10天后过期
 9 document.cookie="userId=828; userName=hulk; expire="+date.toGMTString();
10 //-->
11 </script>
12  
13 删除cookie
14  
15 为了删除一个cookie,可以将其过期时间设定为一个过去的时间,例如:
16  
17 <script language="JavaScript" type="text/javascript">
18 <!--
19 //获取当前时间
20 var date=new Date();
21 //将date设置为过去的时间
22 date.setTime(date.getTime()-10000);
23 //将userId这个cookie删除
24 document.cookie="userId=828; expire="+date.toGMTString();
25 //-->
26 </script>

 

 

注:当没有指明cookie时间时,所创建的cookie有效期默认到用户浏览器关闭止,故被称为会话cookie。

创建一个持久cookie:

?
1
$.cookie(‘cookieName
','
cookieValue',{expires:7});

注:当指明时间时,故称为持久cookie,并且有效时间为天。

创建一个持久并带有效路径的cookie:

?
1
$.cookie(‘cookieName
','
cookieValue
',{expires:7,path:'
/'});

注:如果不设置有效路径,在默认情况下,只能在cookie设置当前页面读取该cookie,cookie的路径用于设置能够读取cookie的顶级目录。

创建一个持久并带有效路径和域名的cookie:

?
1
$.cookie(‘cookieName
','
cookieValue
',{expires:7,path:'
/
',domain: ‘chuhoo.com'
,secure:
false
,raw:
false
});

注:domain: 创建cookie所在网页所拥有的域名;secure:默认是false,如果为true,cookie的传输协议需为https;raw:默认为 false,读取和写入时候自动进行编码和解码(使用encodeURIComponent编码,使用decodeURIComponent解码),关闭 这个功能,请设置为true。

获取cookie:

$.cookie(‘cookieName’);   //如果存在则返回cookieValue,否则返回null。

删除cookie:

?
1
$.cookie(‘cookieName',
null
);

注:如果想删除一个带有效路径的cookie,如下:$.cookie(‘cookieName’,null,{path:’/’});

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/154195.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • Unity3D协程介绍 以及 使用[通俗易懂]

    Unity3D协程介绍 以及 使用[通俗易懂]作者ChevyRay ,2013年9月28日,snaker7译 原文地址:http://unitypatterns.com/introduction-to-coroutines/在Unity中,协程(Coroutines)的形式是我最喜欢的功能之一,几乎在所有的项目中,我都会使用它来控制运动,序列,以及对象的行为。在这个教程中,我将会说明协程是如何工作的,并且会附上一些例子来介绍

  • jq实现图像旋转木马:轮焦点+关于控制+自己主动旋转木马

    jq实现图像旋转木马:轮焦点+关于控制+自己主动旋转木马

  • win8最流畅的设置方法_Windows 12

    win8最流畅的设置方法_Windows 12indowsXP终极优化设置(精心整理篇)◆一、系统优化设置◆1、系统常规优化1)关闭系统属性中的特效,这可是简单有效的提速良方。点击开始→控制面板→系统→高级→性能→设置→在视觉效果中,设置为调整为最佳性能→确定即可。2)“我的电脑”-“属性”-“高级”-“错误报告”-选择“禁用错误汇报”。3)再点“启动和故障恢复”-“设置”,将“将事件写入系统日志”、“发送管理警报”、“自动重新启动”这三项

    2022年10月21日
  • 读《aspnetmvc-stepbystep》笔记

    读《aspnetmvc-stepbystep》笔记  读《aspnetmvc-stepbystep》笔记  这几天读了《aspnetmvc-stepbystep》,为了以后不忘记这次遇到的问题,以及此书中的一些重点观点或者主要内容,就做了一个大概的笔记。  学习软件平台:vs2008、vs2008sp1、mvc1.0rc21、传统的Web框架,如ASP/PHP/ASP.NETWebForms等等,请求的U…

  • Oracle ORA-01017: invalid username/password;logon denied问题解决「建议收藏」

    Oracle ORA-01017: invalid username/password;logon denied问题解决「建议收藏」问题描述:ORA-01017:invalidusername/password;logondenied问题分析:1、该登录用户没有权限。解决办法:第一步,打开SQLPlus第二步,输入用户名和密码。第三步,输入alterusersystemaccountlock;给用户解锁。第四步,输入connectsystem/123456assysdba给用户授权。注:system是用户名,123456是用户的密码。…

  • 最新视频磨皮降噪神器 轻轻松松完成视频磨皮!Beauty box

    最新视频磨皮降噪神器 轻轻松松完成视频磨皮!Beauty box在视频后期中为了追求更好的视觉效果我们经常需要为画面中人物进行磨皮不过这种技术门槛还是比较高的那么有没有一款插件可以帮助我们让PR\FCP等软件也可以像PS一样轻松实现人像磨皮及小伙伴们所想为小伙伴带来一款全新的插件视频磨皮插件Beautybox(含WIN&MAC版本)支持PR\AECS6-CC2020或更高版本支持FCPX10.1.2或更高版本【插件介绍】▼它是人像润色磨皮滤镜,用于人像图片润色,磨.

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号