• Asp.net内置对象之Cookies


    一、了解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对象完成。

    二、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对象并设置过期时间

    1 protected void Page_Load(object sender, EventArgs e)
    2     {
    3         //创建Cookie对象
    4         HttpCookie mycookie = new HttpCookie("MyCookie");//创建一个名称为“MyCookie”的Cookie
    5         mycookie.Value = Server.HtmlEncode("大家好,我是Cookie");//设置Cookie的值
    6         mycookie.Expires = DateTime.Now.AddDays(10);//设置Cookie过期时间
    7         Response.AppendCookie(mycookie);//将一个HTTP Cookie添加到内部Cookie集合中
    8         //Response.Cookies.Add(mycookie);//添加到内部Cookie集合中,与上面相同
    9     }

    2.获取Cookie对象

     1  protected void Page_Load(object sender, EventArgs e)
     2     {
     3         //获取Cookie对象
     4         try
     5         {
     6             HttpCookie mycookie = new HttpCookie("MyCookie");
     7             mycookie.Value = Server.HtmlEncode("Hello,我是Cookie");
     8             mycookie.Expires = DateTime.Now.AddHours(10);
     9             Response.AppendCookie(mycookie);
    10             Response.Write("创建Cookie成功");
    11             Response.Write("<hr>");
    12             //----------使用------------
    13             HttpCookie getMyCookie = Request.Cookies["MyCookie"];//获取Cookie
    14             Response.Write(getMyCookie.Name + getMyCookie.Value + getMyCookie.Expires);//输出
    15         }
    16         catch
    17         {
    18             Response.Write("Cookie 创建失败");
    19         }
    20     }

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

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

    Cookie对象需要利用.NET提供的HttpCookie类重新定义。使用“Response.Cookies.Add”将信息发送并保存到客户端的浏览器,利用Request对象提供的方法可以将Cookies信息读取出来。

    如下实例:

    代码如下:

     1 在default1页面中:
     2 protected void Page_Load(object sender, EventArgs e)
     3     {
     4 
     5     }
     6     protected void Button1_Click(object sender, EventArgs e)
     7     {
     8         //保存cookie信息
     9 
    10         HttpCookie c1 = new HttpCookie("user");//HttpCookie类实例化一个从cookie对象,创建并命名新的cookie
    11         c1.Value = "cookie Value";             //设置单个cookie的值
    12         Response.Cookies.Add(c1);              //将指定的cookie保存到Cookies集合中
    13         Response.Write("<script>alert('保存成功!')</script>");
    14        
    15     }
    16     protected void Button2_Click(object sender, EventArgs e)
    17     {
    18         //提交页面
    19         Response.Redirect("Default2.aspx");
    20     }
    1 在default2页面:
    2   protected void Button1_Click(object sender, EventArgs e)
    3     {
    4         //读取coookie
    5         Response.Write("cookie的名称(Name):" + Request.Cookies["user"].Name + "<br/>");
    6         Response.Write("cookie的值(Value):" + Request.Cookies["user"].Value + "<br/>");
    7 
    8     }

     五、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.安全风险:可伪造修改

    --------------------------------------

    欢迎您,进入 我系程序猿 的cnBlog博客。

    你不能改变你的过去,但你可以让你的未来变得更美好。一旦时间浪费了,生命就浪费了。

    You cannot improve your past, but you can improve your future. Once time is wasted, life is wasted.

    --------------------------------------

    分享到QQ空间  

  • 相关阅读:
    项目经理必备的8个要素:沟通、总结、懂技术
    完工概率计算总结
    PMP--可能会涉及到的计算题
    六顶思考帽子法
    预测技术
    React.Component与React.PureComponent的区别
    简单理解JavaScript,TypeScript和JSX
    自己常用的linux命令
    ES6 promise 用法
    node的express框架接收get/post请求时,参数获取方式
  • 原文地址:https://www.cnblogs.com/jqmtony/p/2910814.html
Copyright © 2020-2023  润新知