欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Asp.net内置对象之Cookies(简介/属性方法/基本操作及实例)

程序员文章站 2024-03-04 09:28:29
一、了解cookies对象 cookies是由web服务器管理的存放在客户计算机中的一个数据集合。这些数据是客户端、服务器端相关的。也就是说客户浏览器每登录一个网站,在c...

一、了解cookies对象

cookies是由web服务器管理的存放在客户计算机中的一个数据集合。这些数据是客户端、服务器端相关的。也就是说客户浏览器每登录一个网站,在cookies中就会保存客户浏览器与该网站的相关信息。即使客户用同一个浏览器登陆了多个网站,在cookies中依然会保存浏览器与多个网站的相关信息,但cookies中这些信息的管理是有序的,当客户浏览器再次登录某网站时,只有cookies中相对应的信息会发生作用。

cookies是web应用程序设计的一项很重要的技术,当web服务器想知道某个用户的相关资料或几个asp.net文件之间传送的数据时就可以使用cookies。

很多网站中的web应用程序都是由多个asp.net文件组成的,为完成某一特定功能,要求在这些asp.net文件之间能够传送一些参数,这些参数就可以存为cookies,这样当文件1想传送数据给文件2时,只要文件1中的数据将参数作为cookies写入cookies.txt文件中,然后文件2再从cookies.txt文件中将指定名称的cookies信息读出即可。cookies中信息的写入工作由response对象完成,cookies信息的读取工作由request对象完成。[在另一篇:asp.net内置对象之request对象中]

二、cookie对象的属性和方法

属性:
(1).name:获取或设置cookie的名称
(2).value:获取或设置cookie的值
(3).expires:获取或设置cookie的过期时间
(4).version:获取或设置cookie的符合http维护状态的版本

方法:
(1).add:增加cookie变量,将指定的cookie保存到cookies集合中
(2).clear:清除cookie集合中变量
(3).get:通过变量名或索引得到cookie变量的值
(4).remove:通过cookie变量名或索引删除cookie对象

三、cookie的基本操作

1.创建cookie对象并设置过期时间

复制代码 代码如下:

protected void page_load(object sender, eventargs e)
{
//创建cookie对象
httpcookie mycookie = new httpcookie("mycookie");//创建一个名称为“mycookie”的cookie
mycookie.value = server.htmlencode("大家好,我是cookie");//设置cookie的值
mycookie.expires = datetime.now.adddays(10);//设置cookie过期时间
response.appendcookie(mycookie);//将一个http cookie添加到内部cookie集合中
//response.cookies.add(mycookie);//添加到内部cookie集合中,与上面相同
}

2.获取cookie对象
复制代码 代码如下:

protected void page_load(object sender, eventargs e)
{
//获取cookie对象
try
{
httpcookie mycookie = new httpcookie("mycookie");
mycookie.value = server.htmlencode("hello,我是cookie");
mycookie.expires = datetime.now.addhours(10);
response.appendcookie(mycookie);
response.write("创建cookie成功");
response.write("<hr>");
//----------使用------------
httpcookie getmycookie = request.cookies["mycookie"];//获取cookie
response.write(getmycookie.name + getmycookie.value + getmycookie.expires);//输出
}
catch
{
response.write("cookie 创建失败");
}
}

四、实例:cookie的写入和读取

response对象包含一个cookies属性。可以通过cookies属性设置、管理cookies的信息。如果指定的cookies不存在则创建该cookies,如果存在则用新值替换旧值。

cookie对象需要利用.net提供的httpcookie类重新定义。使用“response.cookies.add”将信息发送并保存到客户端的浏览器,利用request对象提供的方法可以将cookies信息读取出来。

如下实例:

Asp.net内置对象之Cookies(简介/属性方法/基本操作及实例) Asp.net内置对象之Cookies(简介/属性方法/基本操作及实例)

代码如下:

复制代码 代码如下:

在default1页面中:
protected void page_load(object sender, eventargs e)
{

}
protected void button1_click(object sender, eventargs e)
{
//保存cookie信息

httpcookie c1 = new httpcookie("user");//httpcookie类实例化一个从cookie对象,创建并命名新的cookie
c1.value = "cookie value"; //设置单个cookie的值
response.cookies.add(c1); //将指定的cookie保存到cookies集合中
response.write("<script>alert('保存成功!')</script>");

}
protected void button2_click(object sender, eventargs e)
{
//提交页面
response.redirect("default2.aspx");
}

复制代码 代码如下:

在default2页面:
protected void button1_click(object sender, eventargs e)
{
//读取coookie
response.write("cookie的名称(name):" + request.cookies["user"].name + "<br/>");
response.write("cookie的值(value):" + request.cookies["user"].value + "<br/>");

}

五、cookie对象相比session、application的优缺点

以下总结来自:asp.net 3.5 开发技术大全

相比session和application对象,使用cookie能持久化保存用户信息。cookie保存在客户端,而session和application保存在服务器端,故cookie能长久保存。web应用程序可以通过获取客户端的cookie来进行用户身份认证。

asp.net包含两个cookie集合,通过httprequest的cookie集合进行访问,cookie不是page类的子类,所以使用方法与session和application不同,相比于他们cookie的优点如下:

1.可以配置过期时间
2.简单:cookie是一种基于文本的轻量级结构,包括简单的键值对
3.数据持久:因为保存到客户端
4.无任何服务器资源:因为存储在本地客户端

缺点如下

1.大小限制:
2.不确定性:可能用户删除cookie或者禁用
3.安全风险:可伪造修改

最后推荐一篇:cookies