web前端面试题第五道—简述Cookie,在JS中如何操作Cookie?


Cookie简介

概念

Cookie 可以翻译为“小甜品,小饼干” ,Cookie 在网络系统中几乎无处不在,当我们浏览以前访问过的网站时,网页中可能会出现 :你好 XXX,这会让我们感觉很亲切,就好像吃了一个小甜品一样。这其实是通过访问主机中的一个文件来实现的,这个文件就是 Cookie。一般网络用户习惯用其复数形式 Cookies。

Cookie指某些网站为了辨别用户身份、进行 session 跟踪而储存在用户本地终端上的数据(通常经过加密)。

在默认情况下,Cookie是临时存在的。在一个浏览器窗口打开时,可以设置Cookie,只要该浏览器窗口没有关闭,Cookie就一直有效,在其有效期内,当用户访问同一个 Web 服务器时,浏览器首先要检查本地的Cookies,并将其原样发送给 Web 服务器。这种状态信息称作“Persistent Client State HTTP Cookie” ,简称为 Cookies。

而一旦浏览器窗口关闭后,Cookie也就随之消失。如果想要Cookie在浏览器窗口之后还能继续使用,就需要为Cookie设置一个生存期。所谓生存期也就是Cookie的终止日期,在这个终止日期到达之前,浏览器都可以读取该Cookie。一旦终止日期到达之后,该Cookie将会从Cookie文件中删除。

一个网站可以创建多个Cookie,不同的Cookie可以拥有不同的值,例如将用户名和密码存在Cookie中,就可能用到两个Cookie,一个用来存放用户名,一个用来存放密码,使用Document的Cookie属性可以用来设置与读取Cookie。


JS如何操作Cookie

使用Document的Cookie属性可以用来设置与读取Cookie。Cookie是以键值对的形式保存的,即key=value的格式。各个Cookie之间一般是以“;”分隔。

添加一个cookie

<script language="javascript' type="text/javascript">

function   addCookie(name,value,expiresHours){

var  cookieString=name+"="+escape(value);

//判断是否设置过期时间,0代表关闭浏览器时失效

if(expiresHours>0){

var  date=newDate();

date.setTime(date.getTime+expiresHours*3600*1000);

cookieString=cookieString+"; expires="+date.toGMTString();

}

document.cookie=cookieString;

}

</script>

根据指定名称的Cookie修改Cookie的值

<script language="javascript"  type="text/javascript">

function  editCookie(name,value,expiresHours){

var  cookieString=name+"="+escape(value);

//判断是否设置过期时间,0代表关闭浏览器时失效

if(expiresHours>0){

var  date=newDate();

date.setTime(date.getTime+expiresHours*3600*1000);//单位是多少小时后失效

cookieString=cookieString+"; expires="+date.toGMTString();

}

document.cookie=cookieString;

}

</script>

获取指定名称的cookie值

<script language="javascript" type="text/javascript">

function   getCookie(name){

var   strCookie=document.cookie;

var   arrCookie=strCookie.split("; ");

for(var  i=0;i<arrCookie.length;i++){

var  arr=arrCookie[i].split("=");

if(arr[0]==name){

returnunescape(arr[1]);

}else{

return"";

}

}

}

</script>

删除指定名称的cookie

<script language="javascript"  type="text/javascript">

function   deleteCookie(name){

var  date=newDate();

date.setTime(date.getTime()-10000);//设定一个过去的时间即可

document.cookie=name+"=v; expires="+date.toGMTString();

}

</script>

代码内容出自http://www.jb51.net/article/14566.htm这里,详情请看链接内容

推荐阅读更多精彩内容

  • Cookie简介概念Cookie 可以翻译为“小甜品,小饼干” ,Cookie 在网络系统中几乎无处不在,当我们浏...
    钻石悦阅读 313评论 0 0
  • JavaScript是运行在客户端的脚本,一般是不能够直接设置Session的,因为Session是运行在服务器端...
    hh_王小米阅读 839评论 2 0
  • 作者:晚晴幽草轩www.jeffjade.com/2016/10/31/115-summary-of-cookie...
    饥人谷_Dylan阅读 983评论 0 51
  • 背景在HTTP协议的定义中,采用了一种机制来记录客户端和服务器端交互的信息,这种机制被称为cookie,cooki...
    时芥蓝阅读 1,997评论 1 17
  • 1.使用场景 保存用户登录状态。例如将用户id存储于一个cookie内,这样当用户下次访问该页面时就不需要重新登录...
    jiaomeichen阅读 215评论 1 4