刚整理了一些关于javascript cookies操作的文章,发现这篇文章也不错,推荐大家一起参考,选择需要的,不足的地方主要是对路径的设置,喜欢的朋友可以结合下。
复制代码 代码如下:
一个非常实用的javascript读写cookie函数
复制代码 代码如下:
function Getcookieval(offset)
//获得cookie解码后的值
{
var endstr = documents.cookie.indexOf (";", offset);
if (endstr == -1)
endstr = documents.cookie.length;
return unescape(documents.cookie.substring(offset, endstr));
}
function Setcookie(name, value)
//设定cookie值
{
var expdate = new Date();
var argv = Setcookie.arguments;
var argc = Setcookie.arguments.length;
var expires = (argc > 2) ? argv[2] : null;
var path = (argc > 3) ? argv[3] : null;
var domain = (argc > 4) ? argv[4] : null;
var secure = (argc > 5) ? argv[5] : false;
if(expires!=null) expdate.setTime(expdate.getTime() + ( expires * 1000 ));
documents.cookie = name + "=" + escape (value) +((expires == null) ? "" : ("; expires="+ expdate.toGMTString()))
+((path == null) ? "" : ("; path=" + path)) +((domain == null) ? "" : ("; domain=" + domain))
+((secure == true) ? "; secure" : "");
}
function Delcookie(name)
//删除cookie
{
var exp = new Date();
exp.setTime (exp.getTime() - 1);
var cval = Getcookie (name);
documents.cookie = name + "=" + cval + "; expires="+ exp.toGMTString();
}
function Getcookie(name)
//获得cookie的原始值
{
var arg = name + "=";
var alen = arg.length;
var clen = documents.cookie.length;
var i = 0;
while (i < clen)
{
var j = i + alen;
if (documents.cookie.substring(i, j) == arg)
return Getcookieval (j);
i = documents.cookie.indexOf(" ", i) + 1;
if (i == 0) break;
}
return null;
}
复制代码 代码如下:
如果点了确定,只要不清cookie,以后访问都不会再提示,如果不点确定则每次都会提示。放在js文件里,全站包含
复制代码 代码如下:
1. cookie的兼容性问题
cookie的格式有2个不同的版本,第一个版本,我们称为cookie Version 0,是最初由Netscape公司制定的,也被几乎所有的浏览器支持。而较新的版本,cookie Version 1,则是根据RFC 2109文档制定的。为了确保兼容性,JAVA规定,前面所提到的涉及cookie的操作都是针对旧版本的cookie进行的。而新版本的cookie目前还不被Javax.servlet.http.cookie包所支持。
2. cookie的内容
同样的cookie的内容的字符限制针对不同的cookie版本也有不同。在cookie Version 0中,某些特殊的字符,例如:空格,方括号,圆括号,等于号(=),逗号,双引号,斜杠,问号,@符号,冒号,分号都不能作为cookie的内容。这也就是为什么我们在例子中设定cookie的内容为"Test_Content"的原因。
虽然在cookie Version 1规定中放宽了限制,可以使用这些字符,但是考虑到新版本的cookie规范目前仍然没有为所有的浏览器所支持,因而为保险起见,我们应该在cookie的内容中尽量避免使用这些字符



