javascript cookies 存、取、删除实例

来源:互联网 发布:小学生读英语软件下载 编辑:程序博客网 时间:2024/05/22 15:06

  1. <script>
  2. //写cookies函数 作者:翟振凯
  3. function SetCookie(name,value)//两个参数,一个是cookie的名子,一个是值
  4. {
  5.     var Days = 30; //此 cookie 将被保存 30 天
  6.     var exp  = new Date();    //new Date("December 31, 9998");
  7.     exp.setTime(exp.getTime() + Days*24*60*60*1000);
  8.     document.cookie = name + "="+ escape (value) + ";expires=" + exp.toGMTString();
  9. }
  10. function getCookie(name)//取cookies函数        
  11. {
  12.     var arr = document.cookie.match(new RegExp("(^| )"+name+"=([^;]*)(;|$)"));
  13.      if(arr != nullreturn unescape(arr[2]); return null;
  14. }
  15. function delCookie(name)//删除cookie
  16. {
  17.     var exp = new Date();
  18.     exp.setTime(exp.getTime() - 1);
  19.     var cval=getCookie(name);
  20.     if(cval!=null) document.cookie= name + "="+cval+";expires="+exp.toGMTString();
  21. }
  22. SetCookie ("xiaoqi""3")
  23. alert(getCookie('xiaoqi'));
  24. </script>

一个非常实用的javascript读写Cookie函数

一个非常实用的javascript读写Cookie函数  

  1. function  GetCookieVal(offset)
  2. //获得Cookie解码后的值
  3. {
  4. var  endstr  =  documents.cookie.indexOf  (";",  offset);
  5. if  (endstr  ==  -1)
  6. endstr  =  documents.cookie.length;
  7. return  unescape(documents.cookie.substring(offset,  endstr));
  8. }
  9. function  SetCookie(name,  value)
  10. //设定Cookie值
  11. {
  12. var  expdate  =  new  Date();
  13. var  argv  =  SetCookie.arguments;
  14. var  argc  =  SetCookie.arguments.length;
  15. var  expires  =  (argc  >  2)  ?  argv[2]  :  null;
  16. var  path  =  (argc  >  3)  ?  argv[3]  :  null;
  17. var  domain  =  (argc  >  4)  ?  argv[4]  :  null;
  18. var  secure  =  (argc  >  5)  ?  argv[5]  :  false;
  19. if(expires!=null)  expdate.setTime(expdate.getTime()  +  (  expires  *  1000  ));
  20. documents.cookie  =  name  +  "="  +  escape  (value)  +((expires  ==  null)  ?  ""  :  (";  expires="+  expdate.toGMTString()))
  21. +((path  ==  null)  ?  ""  :  (";  path="  +  path))  +((domain  ==  null)  ?  ""  :  (";  domain="  +  domain))
  22. +((secure  ==  true)  ?  ";  secure"  :  "");
  23. }
  24. function  DelCookie(name)
  25. //删除Cookie
  26. {
  27. var  exp  =  new  Date();
  28. exp.setTime  (exp.getTime()  -  1);
  29. var  cval  =  GetCookie  (name);
  30. documents.cookie  =  name  +  "="  +  cval  +  ";  expires="+  exp.toGMTString();
  31. }
  32. function  GetCookie(name)
  33. //获得Cookie的原始值
  34. {
  35. var  arg  =  name  +  "=";
  36. var  alen  =  arg.length;
  37. var  clen  =  documents.cookie.length;
  38. var  i  =  0;
  39. while  (i  <  clen)
  40. {
  41. var  j  =  i  +  alen;
  42. if  (documents.cookie.substring(i,  j)  ==  arg)
  43. return  GetCookieVal  (j);
  44. i  =  documents.cookie.indexOf("  ",  i)  +  1;
  45. if  (i  ==  0)  break;
  46. }
  47. return  null;
  48. }


  1. <SCRIPT  language="javascript">
  2. <!--
  3. function  openpopup(){
  4. url="popup.htm"
  5. window.open("gonggao.htm","gonggao","width=260,height=212,left=200,top=0")
  6. }
  7. function  get_cookie(Name)  {
  8. var  search  =  Name  +  "="
  9. var  returnvalue  =  "";
  10. if  (documents.cookie.length  >  0)  {
  11. offset  =  documents.cookie.indexOf(search)
  12. if  (offset  !=  -1)  {
  13. offset  +=  search.length
  14. end  =  documents.cookie.indexOf(";",  offset);
  15. if  (end  ==  -1)
  16. end  =  documents.cookie.length;
  17. returnvalue=unescape(documents.cookie.substring(offset,  end))
  18. }
  19. }
  20. return  returnvalue;
  21. }
  22. function  helpor_net(){
  23. if  (get_cookie('popped')==''){
  24. openpopup()
  25. documents.cookie="popped=yes"
  26. }
  27. }
  28. helpor_net()
  29. //-->
  30. </SCRIPT>

如果点了确定,只要不清cookie,以后访问都不会再提示,如果不点确定则每次都会提示。放在js文件里,全站包含

  1. <SCRIPT LANGUAGE="JavaScript">
  2. <!--
  3. var the_cookie = document.cookie;
  4. var broken_cookie = the_cookie.split(":");
  5. var the_visiteraccepted = unescape(broken_cookie[1]);
  6. //
  7. if (the_visiteraccepted=="undefined"){
  8.         var tmp=confirm('中国人何时何地。');
  9.         if(tmp==false){
  10.                 window.close();
  11.         }else{
  12.                 var the_visiteraccepted = 1;          
  13.         var the_cookie = "ILoveChina=visiteraccepted:" + escape(the_visiteraccepted);                                 
  14.         document.cookie = the_cookie;
  15.         }
  16. }
  17. //-->
  18. </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"的原因。

原创粉丝点击