Javascript中的Cookie应用

一 什么是 Cookie
Cookie 是一些数据, 存储于你电脑上的文本文件中。
当 web 服务器向浏览器发送 web 页面时,在连接关闭后,服务端不会记录用户的信息。
Cookie 的作用就是用于解决 "如何记录客户端的用户信息":
当用户访问 web 页面时,他的名字可以记录在 cookie 中。
在用户下一次访问该页面时,可以在 cookie 中读取用户访问记录。
Cookie 以名/值对形式存储,如下所示:
username=John Doe
当浏览器从服务器上请求 web 页面时, 属于该页面的 cookie 会被添加到该请求中。服务端通过这种方式来获取用户的信息。
 
二 使用 JavaScript 创建Cookie
JavaScript 可以使用 document.cookie 属性来创建 、读取、及删除 cookie。
JavaScript 中,创建 cookie 如下所示:
document.cookie="username=John Doe";
您还可以为 cookie 添加一个过期时间(以 UTC 或 GMT 时间)。默认情况下,cookie 在浏览器关闭时删除:
document.cookie="username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT";
您可以使用 path 参数告诉浏览器 cookie 的路径。默认情况下,cookie 属于当前页面。
document.cookie="username=John Doe; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/";
 
三 使用 JavaScript 读取 Cookie
在 JavaScript 中, 可以使用以下代码来读取 cookie:
var x = document.cookie;
注意 document.cookie 将以字符串的方式返回所有的 cookie,类型格式: cookie1=value; cookie2=value; cookie3=value;
 
四 使用 JavaScript 修改 Cookie
在 JavaScript 中,修改 cookie 类似于创建 cookie,如下所示:
document.cookie="username=John Smith; expires=Thu, 18 Dec 2013 12:00:00 GMT; path=/";
旧的 cookie 将被覆盖。
 
五 使用 JavaScript 删除 Cookie
删除 cookie 非常简单。您只需要设置 expires 参数为以前的时间即可,如下所示,设置为 Thu, 01 Jan 1970 00:00:00 GMT:
document.cookie = "username=; expires=Thu, 01 Jan 1970 00:00:00 GMT";
注意,当您删除时不必指定 cookie 的值。
 
六 Cookie 字符串
document.cookie 属性看起来像一个普通的文本字符串,其实它不是。
即使您在 document.cookie 中写入一个完整的 cookie 字符串, 当您重新读取该 cookie 信息时,cookie 信息是以名/值对的形式展示的。
如果您设置了新的 cookie,旧的 cookie 不会被覆盖。 新 cookie 将添加到 document.cookie 中,所以如果您重新读取document.cookie,您将获得如下所示的数据:
cookie1=value; cookie2=value;
 
七 代码
<script type="text/javascript">
var setCookie = function(name , value)
{
	// 定义变量,保存当前时间
	var expdate = new Date();
	// 将expdate的月份 + 1。
	expdate.setMonth(expdate.getMonth() + 1);
	// 添加Cookie
	document.cookie = name + "=" + escape(value) ;
		+ "; expires=" + expdate.toGMTString() +  ";";
}
var getCookie = function(name) 
{
	// 访问Cookie的name开始处
	var offset = document.cookie.indexOf(name)
	// 如果找到指定Cookie
	if (offset != -1) 
	{
		// 从Cookie名后位置开始搜索
		offset += name.length + 1;
		// 找到Cookie名后第一个分号(;)
		end = document.cookie.indexOf(";", offset) ;
		// 如果没有找到分号
		if (end == -1)
		{
			end = document.cookie.length;
		}
		// 截断字符串中Cookie的值
		return unescape(document.cookie.substring(offset, end));
	}
	else
	{
		return "";
	}
}
setCookie('user' , 'crazyit.org');
alert(getCookie('user'));
</script>
 
 
八 运行结果

 

猜你喜欢

转载自cakin24.iteye.com/blog/2369734