javascript操作cookie方法函数集合

  问题:

  使得在访问页面的时候能够沿用上次的设置,或者在不同的页面间共享数据。比如用户在访问网站的时候设置了页面字体的大小,那么会希望下次访问的时候仍然能使用同样的设置进行浏览,而不用重复设置。

  解决方案:

  在用户浏览页面并进行设置时,将这些设置保存在cookie中,下次访问的时候读取cookie中的设置。

  参考下面的脚本:

  

复制代码 代码如下:

  // utility function to retrieve an expiration data in proper format;

  function getExpDate(days, hours, minutes)

  {

  var expDate = new Date();

  if(typeof(days) == "number" && typeof(hours) == "number" && typeof(hours) == "number")

  {

  expDate.setDate(expDate.getDate() + parseInt(days));

  expDate.setHours(expDate.getHours() + parseInt(hours));

  expDate.setMinutes(expDate.getMinutes() + parseInt(minutes));

  return expDate.toGMTString();

  }

  }

  //utility function called by getCookie()

  function getCookieVal(offset)

  {

  var endstr = document.cookie.indexOf(";", offset);

  if(endstr == -1)

  {

  endstr = document.cookie.length;

  }

  return unescape(document.cookie.substring(offset, endstr));

  }

  // primary function to retrieve cookie by name

  function getCookie(name)

  {

  var arg = name + "=";

  var alen = arg.length;

  var clen = document.cookie.length;

  var i = 0;

  while(i < clen)

  {

  var j = i + alen;

  if (document.cookie.substring(i, j) == arg)

  {

  return getCookieVal(j);

  }

  i = document.cookie.indexOf(" ", i) + 1;

  if(i == 0) break;

  }

  return;

  }

  // store cookie value with optional details as needed

  function setCookie(name, value, expires, path, domain, secure)

  {

  document.cookie = name + "=" + escape(value) +

  ((expires) ? "; expires=" + expires : "") +

  ((path) ? "; path=" + path : "") +

  ((domain) ? "; domain=" + domain : "") +

  ((secure) ? "; secure" : "");

  }

  // remove the cookie by setting ancient expiration date

  function deleteCookie(name,path,domain)

  {

  if(getCookie(name))

  {

  document.cookie = name + "=" +

  ((path) ? "; path=" + path : "") +

  ((domain) ? "; domain=" + domain : "") +

  "; expires=Thu, 01-Jan-70 00:00:01 GMT";

  }

  }

  使用getCookie(name)函数来读取cookie中保存的值,参数name为cookie项的名称。如果该cookie项不存在则返回一个空字符串。

  使用setCookie()函数来保存cookie项的值,其中第一、二两个参数分别为cookie项的名称和值。如果想为其设置一个过期时间,那么就需要设置第三个参数,这里需要通过getExpDate()获得一个正确格式的参数。

  最后,使用deleteCookie()来删除一个已存在的cookie项,实际上是通过让该项过期。

  cookie将数据保存在客户端。页面的脚本只能读取所在域和服务器的cookie值,如果域内有多个服务器,那么需要设置第五个参数,以指定服务器。浏览器的容量一般限定为每服务器20个name/value对,每个cookie项不超过4000个字符,更现实点,单个cookie项应少于2000字符,也就是说不要用cookie在客户端保存大容量数据。

  不同的浏览器保存cookie的方式也有所不同。IE为每个域的cookie建立一个文本文件,而Netscape则将所有的cookie存储在同一个文本文件中。

  注意:cookie存放在客户端,所以会受到浏览器设置的影响,比如用户可能会禁用cookie。要检测浏览器是否支持cookie,使用属性navigator.cookieEnabled来判断。

  

复制代码 代码如下:

  <script>

  //写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 != null) return 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 ("xiaoqi", "3")

  alert(getCookie('xiaoqi'));

  </script>

  一个非常实用的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;

  }

  <SCRIPT language="javascript">

  <!--

  function openpopup(){

  url="popup.htm"

  window.open("gonggao.htm","gonggao","width=260,height=212,left=200,top=0")

  }

  function get_cookie(Name) {

  var search = Name + "="

  var returnvalue = "";

  if (documents.cookie.length > 0) {

  offset = documents.cookie.indexOf(search)

  if (offset != -1) {

  offset += search.length

  end = documents.cookie.indexOf(";", offset);

  if (end == -1)

  end = documents.cookie.length;

  returnvalue=unescape(documents.cookie.substring(offset, end))

  }

  }

  return returnvalue;

  }

  function helpor_net(){

  if (get_cookie('popped')==''){

  openpopup()

  documents.cookie="popped=yes"

  }

  }

  helpor_net()

  //-->

  </SCRIPT>

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

  

复制代码 代码如下:

  <SCRIPT LANGUAGE="JavaScript">

  <!--

  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的内容中尽量避免使用这些字符