cookie问题
cookie的定义:“cookie 是存储于访问者的计算机中的变量。每当同一台计算机通过浏览器请求某个页面时,就会发送这个 cookie。你可以使用 JavaScript 来创建和取回 cookie 的值。”
cookie 是访问过的网站创建的文件,用于存储浏览信息,例如个人资料信息。
cookie就是用于客户端与服务器之间的通信。
1.访问cookie的方法:
function getCookie(c_name){ if (document.cookie.length>0){ //先查询cookie是否为空,为空就return "" c_start=document.cookie.indexOf(c_name + "=") //通过String对象的indexOf()来检查这个cookie是否存在,不存在就为 -1 if (c_start!=-1){ c_start=c_start + c_name.length+1 //最后这个+1其实就是表示"="号啦,这样就获取到了cookie值的开始位置 c_end=document.cookie.indexOf(";",c_start) //其实我刚看见indexOf()第二个参数的时候猛然有点晕,后来想起来表示指定的开始索引的位置...这句是为了得到值的结束位置。因为需要考虑是否是最后一项,所以通过";"号是否存在来判断 if (c_end==-1) c_end=document.cookie.length return unescape(document.cookie.substring(c_start,c_end)) //通过substring()得到了值。想了解unescape()得先知道escape()是做什么的,都是很重要的基础,想了解的可以搜索下,在文章结尾处也会进行讲解cookie编码细节 } } return "" }
2.cookie的编码细节:
需要使用escape()对字符串进行编码,或者使用encodeURIComponent()进行编码
3.个人理解版本
var Cookie = { get: function(name){
var ck = document.cookie, result="";
if(ck.length > 0){
var start = ck.indexOf(encodeURIComponent(name)+"=");
if(start !== -1){
var end = ck.indexOf(";",start);
if(end === -1) end = ck.length;
result = encodeURIComponent(ck.slice(start+name.length+1,end));
}
}
return result;
},
set:function(name,value,expires,path,domain,secure){
var ckText = encodeURIComponent(name) + "=" + encodeURIComponent(value);
if(expires instanceof Date){
ckTetx += ";expires=" + expires.toGMTString();
}
if(path){
ckText += ";path=" +path;
}
if(domain){
ckText += ";domain=" + domain;
}
if(secure){
ckText += ";secure";
}
document.cookie = ckText;
},
unset: function(name,path,domain,secure){
this.set(name,"",new Date(0),path,domain,secure)
}
}
参考资料: