asp.net cookie的使用.

Cookie就是服务器暂时存放在你的电脑里的资料(.txt格式的文本文件),好让服务器用来辨认你的计算机。当你在浏览网站的时候,Web服务器会先送一小小资料放在你的计算机上,Cookies 会帮你在网站上所打的文字或是一些选择都记录下来。当下次你再访问同一个网站,Web服务器会先看看有没有它上次留下的Cookies资料,有的话,就会依据Cookie里的内容来判断使用者,送出特定的网页内容给你。

cookie的限制:必须通过浏览器操作,如果浏览器禁用cookie,则无法工作;信息只能是文本,大小限制在4kb。

实现单值的cookie设置:

首先在页面中添加一个按钮和文本

在按钮的提交事件中,将cookie值写到客户端

protected void Button1_Click(object sender, EventArgs e)
    {
        HttpCookie ck_1 = new HttpCookie("animal");//声明一个名称为animal的cookie
        ck_1.Value = "猫";
        ck_1.Expires = DateTime.Now.AddDays(1);//设置这个cookie在一天后过期,如果不设置过期时间,那么在浏览器关闭后cookie失效。
        Response.Cookies.Add(ck_1);//发送写入cookie指令给浏览器

    }

在页面的load方法中读取cookie

 protected void Page_Load(object sender, EventArgs e)
    {
      if(Request .Cookies ["animal"]!=null)
      { Label1.Text = "读取的cookie值为:" + Request.Cookies["animal"].Value; }
    }

运行程序,页面出来后点击按钮,这时会将cookie写到客户端。然后再点击一次按钮,当程序执行load方法的时候就能读取cookie值了。但是却是乱码

但是,结束调试,再次运行程序进入这个页面的时候,就没有乱码了。这可能是因为编码和解码不一致造成的,因此用ck_1.Value = Server.UrlEncode("猫");这种方式来编码,同时,用Server.UrlDecode(Request.Cookies["animal"].Value)来解码。但是这样在运行程序后,点击一次按钮将cookie写到客户端,再点第二次按钮的时候,程序似乎并没有找到这个cookie。然后从新调试,这时页面就找到这个cookie了,但是你刷新页面,在代码中仍然表示没有找到这个cookie,即这个cookie为null。每次都是要重新启动调试才能获取这个cookie。这个问题的原因似乎是一个时间间隔,就是说,当页面打开后,通过load方法获取了这个cookie值,但是要隔一段时间,你再来刷新页面的时候,就能获取这个cookie的值,如果你是连续两次的刷新获取这个cookie值,就不行。当然,你如果在load方法中用两行代码来获取同一个cookie还是可以获取的。

因此代码中的if(Request .Cookies ["animal"]!=null)这个判断就显得非常重要了,这样可以避免页面在第一次加载完成,获取了cookie的值以后,紧接着又刷新了一次页面反而导致页面的显示结果不对。

实现单值cookie信息删除:

由于cookie是存放在客户端硬盘的,因此不能像删除变量值那样,这需要将cookie的有效期Expires设置为一个过期的日期。标准写法是

Response.Cookies["animal"].Expires = DateTime.MinValue;

对于同类型的信息可以保存在一个cookie中,这样就可以使得这些信息管理起来比较容易,最主要的是有相同的有效期。

以下示例显示了编写同一 Cookie 的两种不同方法,其中的每个 Cookie 都带有两个子键:
Response.Cookies("userInfo")("userName") = "mike"
Response.Cookies("userInfo")("lastVisit") = DateTime.Now.ToString
Response.Cookies("userInfo").Expires = DateTime.Now.AddDays(1)
HttpCookie aCookie = New HttpCookie("userInfo") aCookie.Values("userName") = "mike" aCookie.Values("lastVisit") = DateTime.Now.ToString aCookie.Expires = DateTime.Now.AddDays(1) Response.Cookies.Add(aCookie)

多值cookie结构:

[主键名称]

  [子键名称]:[子键值]

   [子键名称2]:[子键值2]

   [子键名称3]:[子键值3]

[主键名称2]

  [子键名称]:[子键值]

   [子键名称2]:[子键值2]

   [子键名称3]:[子键值3]

下面的代码演示了如何添加多值的cookie

 protected void Button1_Click(object sender, EventArgs e)
    {
        HttpCookie ck_1 = new HttpCookie("people");
        ck_1.Values.Add("name", "小王");
        ck_1.Values.Add("age", "18");
        ck_1.Values.Add("sex", "男");
        ck_1.Expires = DateTime.Now.AddDays(1);
        Response.Cookies.Add(ck_1);
        ck_1 = new HttpCookie("student");
        ck_1.Values.Add("name", "小赵");
        ck_1.Values.Add("age", "15");
        ck_1.Values.Add("sex", "女");
        ck_1.Expires = DateTime.Now.AddDays(1);
        Response.Cookies.Add(ck_1);

        Label1.Text += Request.Cookies["people"].Values["name"];
        Label2.Text += Request.Cookies["people"].Values["sex"];
        Label3.Text += Request.Cookies["people"].Values["age"];
     HttpCookie ck = Request.Cookies["student"];     Label4.Text += ck.Values["name"];     Label5.Text +=ck.Values["age"];     Label6.Text += ck.Values["sex"];
    }

多值cookie的主键删除与清除单值cookie完全相同,Response.Cookies["people"].Expires = DateTime.MinValue;

另外一种非标准的写法:ck=response.cookie["keyname"]这样会在会话期间,保留一个没有value的空key。

对子键的修改:

protected void Page_Load(object sender, EventArgs e)
    {
        HttpCookie ck = Request.Cookies["student"];
        Label4.Text += ck.Values["name"];
        Label5.Text += ck.Values["age"];
        Label6.Text += ck.Values["sex"];
    }
protected void Button2_Click(object sender, EventArgs e)
    {
        HttpCookie ck = Request.Cookies["student"];
        ck.Values.Set("name", "小红");//对多值cookie的修改用的是set,而对单值cookie的修改用add
        Label4.Text += ck.Values["name"];
    }

如上面的代码,当网页加载完成后,文本中能正常显示student   cookie中的值,但是问题出在,当网页加载完成后,点击按钮来修改这个cookie,却发现这个cookie是null。根本没法获取,但是在过一段时间后才点击按钮,就能正常获取这个cookie了,这中间有一段时间间隔。

删除一个子键:

ck.values.remove("keyName");

删除全部子键:ck.values.clear();

时间: 2024-10-25 15:00:33

asp.net cookie的使用.的相关文章

ASP.NET Cookie 概述【转】

来源:http://msdn.microsoft.com/zh-cn/library/ms178194(VS.80).aspx ASP.NET Cookie 概述 Cookie 提供了一种在 Web 应用程序中存储用户特定信息的方法.例如,当用户访问您的站点时,您可以使用 Cookie 存储用户首选项或其他信息.当该用户再次访问您的网站时,应用程序便可以检索以前存储的信息. 什么是 Cookie? Cookie 是一小段文本信息,伴随着用户请求和页面在 Web 服务器和浏览器之间传递.Cooki

【转】asp.net Cookie值中文乱码问题解决方法

来源:脚本之家.百度空间.网易博客 http://www.jb51.net/article/34055.htm http://hi.baidu.com/honfei http://tianminqiang.blog.163.com/blog/#m=0 ============================================================================== cookie中怎么保存中文 在用cookie保存用户名的时候,发现cookie值不能存中文

ASP.NET Cookie对象到底是毛啊?(简单小例子)

记得刚接触asp.net的时候,就被几个概念搞的头痛不已,比如Request,Response,Session和Cookie.然后还各种在搜索引擎搜,各种问同事的,但是结果就是自己还是很懵的节奏. 那cookie到底是毛啊?下面是我最不喜欢的一种解释方式(官方定义吧应该叫,我这种智商根本读不懂嘛~) Cookie对象也称缓存对象,该对象用于保存客户端浏览器请求的服务器页面,也可用它存放非敏感性的用户信息. 以前根本读不懂啊,现在其实也懵懵的. 还是用例子能把这个概念搞明白 1.做一个用户登录的界

Asp.Net Cookie用法

比如建立一个名为cookiePhone,值为2598998的cookie HttpCookie cookie = new HttpCookie["cookiePhone"];cookie.Value = "2598998;Response.AppendCookie(cookie); 取出Cookie值也很简单 HttpCookie cookie = Request.Cookies["cookiePhone"];cookieValue = cookie.Va

ASP.NET Cookie是怎么生成的

原文:ASP.NET Cookie是怎么生成的 ASP.NET Cookie是怎么生成的 可能有人知道Cookie的生成由machineKey有关,machineKey用于决定Cookie生成的算法和密钥,并如果使用多台服务器做负载均衡时,必须指定一致的machineKey用于解密,那么这个过程到底是怎样的呢? 如果需要在.NET Core中使用ASP.NET Cookie,本文将提到的内容也将是一些必经之路. 抽丝剥茧,一步一步分析 首先用户通过AccountController->Login

巧用ASP.NET Cookie

一.Cookie是什么 Cookie是一小段文本信息,存在客户端硬盘上的长度不超过4KB的文本文件.伴随着用户请求和页面在Web服务器和浏览器之间传递用户每次访问站点时,Web应用程序都可以读取Cookie包含的信息. 二.工作原理 由于HTTP是一种无状态的协议,服务器单从网络连接上无从知道客户身份.怎么办呢?就给客户端们颁发一个通行证吧,每人一个,无论谁访问都必须携带自己通行证.这样服务器就能从通行证上确认客户身份了.这就是Cookie的工作原理.Cookie实际上是一小段的文本信息.客户端

数往知来 ASP.NET Cookie Session Url <二十九>

ViewState_Cookie 一.Request的几个成员 -->Request.UrlReferrer():请求的来源,就是客户端上一次请求的url地址,防止盗链 -->Request.UrlHostAddress;获取浏览器端的IP地址,通过Socket.RemoveEndPoint  获得的客户端IP地址 -->Request.MapPath();   跟context.ServerMapPath()一样 二.Response的成员 -->Respose.Buffer 缓

ASP.NET Cookie概念、CURD操作、原理、实际运用

会话就WEB开发来说,一个会话就是你通过浏览器与服务器之间的一次通话,只不过这种通话是以用浏览器浏览的方式来实现的. 就会话的应用来说,一般会话是用来识别用户的,比如你可以使用会话级变量记录当前用户已经输入的用户名密码,这样就不用他每次输入了,还可以用来记录一些其他的与当前这一次通话有关的信息.一旦你关闭了浏览 器,虽然会话没有结束,但是你重新打开浏览器时,已经不能再次利用上一次的会话了,它会新建一个会话.而服务器会根据预先的设置在超时后自动关闭会话,你也可以手动结束会话. 一.Cookie的基

C#ASP.NET Cookie 概述

1 Cookie 提供了一种在 Web 应用程序中存储用户特定信息的方法.例如,当用户访问您的站点时,您可以使用 Cookie 存储用户首选项或其他信息.当该用户再次访问您的网站时,应用程序便可以检索以前存储的信息. 2 3 什么是 Cookie? 4 6 Cookie 是一小段文本信息,伴随着用户请求和页面在 Web 服务器和浏览器之间传递.Cookie 包含每次用户访问站点时 Web 应用程序都可以读取的信息. 7 8 例如,如果在用户请求站点中的页面时应用程序发送给该用户的不仅仅是一个页面

ASP.NET Cookie 概述

Cookie 提供了一种在 Web 应用程序中存储用户特定信息的方法.例如,当用户访问您的站点时,您可以使用 Cookie 存储用户首选项或其他信息.当该用户再次访问您的网站时,应用程序便可以检索以前存储的信息. 什么是 Cookie? Cookie 是一小段文本信息,伴随着用户请求和页面在 Web 服务器和浏览器之间传递.Cookie 包含每次用户访问站点时 Web 应用程序都可以读取的信息. 例如,如果在用户请求站点中的页面时应用程序发送给该用户的不仅仅是一个页面,还有一个包含日期和时间的