javascript 操作cookies 存(设置)、读取、删除函数实例详解

以前一般没想过要在JavaScript里进行COOKIES操作,不过今天碰到了,所以也发一下,作为收藏吧,以下是将这几个功能分别写成了函数.方便使用

<SCRIPT LANGUAGE="JavaScript">

//写cookies函数 
function SetCookie(name,value)//两个参数,一个是cookie的名子,一个是值
{
    
var Days = 30//此 cookie 将被保存 30 天
    var exp  = new Date();    //new Date("December 31, 9998");
    exp.setTime(exp.getTime() + Days*24*60*60*1000);
    document.cookie 
= name + "="+ escape (value) + ";expires=" + exp.toGMTString();
}
function getCookie(name)//读取cookies函数        
{
    
var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
     
if(arr != nullreturn unescape(arr[2]); return null;

}
function delCookie(name)//删除cookie
{
    
var exp = new Date();
    exp.setTime(exp.getTime() 
- 1);
    
var cval=getCookie(name);
    
if(cval!=null) document.cookie= name + "="+cval+";expires="+exp.toGMTString();
}


//简单例子
//
SetCookie ("name", www.buslfy.cn)
//
alert(getCookie(name));
</script>


--------------------------------------------------------------------------------


<SCRIPT LANGUAGE="JavaScript">
function  GetCookieVal(offset)
//获得Cookie解码后的值
{
var  endstr  =  documents.cookie.indexOf  (";",  offset);
if  (endstr  ==  -1)
endstr  
=  documents.cookie.length;
return  unescape(documents.cookie.substring(offset,  endstr));
}

如果点了确定,只要不清cookie,以后访问都不会再提示,如果不点确定则每次都会提示。放在js文件里,全站包含
<!--
var the_cookie = document.cookie;
var broken_cookie = the_cookie.split(":");
var the_visiteraccepted = unescape(broken_cookie[1]);
//
if (the_visiteraccepted=="undefined"){
        
var tmp=confirm('中国人何时何地。');
        
if(tmp==false){
                window.close();
        }
else{
                
var the_visiteraccepted = 1;          
        
var the_cookie = "ILoveChina=visiteraccepted:" + escape(the_visiteraccepted);                                 
        document.cookie 
= the_cookie;
        }
}
//-->
</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的内容中尽量避免使用这些字符

posted @ 2009-10-12 11:38  旭 日  阅读(290)  评论(0编辑  收藏  举报