作者:zr8744814 | 来源:互联网 | 2022-07-05 13:48
刚整理了一些关于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 {
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;
}
代码如下:
《SCRIPT》
如果点了确定,只要不清COOKIE,以后访问都不会再提示,如果不点确定则每次都会提示。放在js文件里,全站包含
代码如下:
《SCRIPT》
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的内容中尽量避免使用这些字符