js cookies存取删操作实例

//写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‘));

以下是一个非常实用的 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>

Cookie的兼容性问题

Cookie的格式有2个不同的版本,第一个版本,我们称为Cookie Version 0,是最初由Netscape公司制定的,也被几乎所有的浏览器支持。而较新的版本,Cookie Version 1,则是根据RFC 2109文档制定的。为了确保兼容性,JAVA规定,前面所提到的涉及Cookie的操作都是针对旧版本的Cookie进行的。而新版本的Cookie目前还不被Javax.servlet.http.Cookie包所支持。

Cookie的内容

同样的Cookie的内容的字符限制针对不同的Cookie版本也有不同。在Cookie Version 0中,某些特殊的字符,例如:空格,方括号,圆括号,等于号(=),逗号,双引号,斜杠,问号,@符号,冒号,分号都不能作为Cookie的内容。这也就是为什么我们在例子中设定Cookie的内容为"Test_Content"的原因。

虽然在Cookie Version 1规定中放宽了限制,可以使用这些字符,但是考虑到新版本的Cookie规范目前仍然没有为所有的浏览器所支持,因而为保险起见,我们应该在Cookie的内容中尽量避免使用这些字符。

时间: 2024-08-08 05:38:48

js cookies存取删操作实例的相关文章

node.js下mongoose简单操作实例

Mongoose API : http://mongoosejs.com/docs/api.html // mongoose 链接var mongoose = require('mongoose');var db       = mongoose.createConnection('mongodb://127.0.0.1:27017/NodeJS'); // 链接错误db.on('error', function(error) {    console.log(error);}); // Sch

[转] node.js下mongoose简单操作实例

Mongoose API : http://mongoosejs.com/docs/api.html // mongoose 链接 var mongoose = require('mongoose'); var db = mongoose.createConnection('mongodb://127.0.0.1:27017/NodeJS'); // 链接错误 db.on('error', function(error) { console.log(error); }); // Schema 结

js中select操作实例

window.onload=function(){ //创建select var select1= document.createElement("select"); select1.id="select1"; for(var i=0;i<5;i++){ //创建option var option=document.createElement("option"); //var option=new option(); option.valu

chart.js操作实例(前后台互通)

前提:需要导入chart.js 我的项目环境是:SpringMVC+mongodb SpringMVC的controller层: /** * 查询得到财务信息报表 * @author liupeng * @param request * @return * @throws UnknownHostException * @throws ParseException */ @RequestMapping(value="/innerChartOutForFinal") public Mode

js的dom测试及实例代码

js的dom测试及实例代码 一.总结 一句话总结: 1.需要记得 创建 标签和创建文本节点都是document的活:document.createTextNode("Rockets的姚明"); 2.appendChild就是 标签 都可以干的活:document.body.appendChild(hr1); 1.需要记得 创建 标签和创建文本节点都是document的活? var div1 = document.createElement("div"); var t

js中的二进制操作相关类型和方法

Blob数据对象 MDN官方解释Blob对象:一个Blob对象就是一个包含有只读原始数据的类文件对象.Blob对象中的数据并不一定得是JavaScript中的原生形式.File接口基于Blob, 继承了Blob的功能,并且扩展支持了用户计算机上的本地文件. 创建Blob对象的方法有几种,可以调用Blob构造函数,还可以使用一个已有Blob对象上的slice()方法切出另一个Blob对象,还可以调用canvas对象上的toBlob方法. 实际上,Blob是计算机通用术语之一,全称写作:BLOB(b

ajax跨域请求操作实例

<!doctype html> <html lang="en"> <head> <meta charset="UTF-8"> <title>JS</title> <style> #box{ width:600px; height:200px; padding:20px; border:1px solid #999; } </style> </head> <

jquery 操作实例一

<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%> <%@include file="../../common/taglib.jsp"%> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html&g

文件操作实例

1.文件操作之bytes模式 1.除了上篇所介绍的'r','w','a'只读只写只追加模式外,大家可能意识到一个问题就是这种操作只能对纯文本的文件进行操作,然而现在很多文件都是带有图片或者音频视频的文件,那该如何操作执行文件呢?接下来介绍文件操作其他三种类似模式 我们上面的'r','w','a'起始都是'rt','wt','at'即文本文件操作的只读只写只追加,要想操作文本文件以外的文件类型,那就需要在这个t的位置上做一些手脚了,对于非文本文件,我们只能使用b模式,"b"表示以字节的方