在新技术大军横空出世年代, Cookie 似乎已被遗忘. 但网页设计中依然少不了它的身影, 这里就本人多年对它的应用做以总结, 可能不是最全面的, 但一定是最实用的. Cookie早已不是不可替代, 不是必不可少, 也因此失去了很多色彩, 很多人把它形容为一鸡肋,食之无味, 弃之可惜. 但若都以此评判, 似乎我们很多技术都很无味, 而似乎都不可缺少. 以我看来, 技术最好少做对比, 选择多了, 困惑也就多了, 心不静, 看什么都是有用而无味. 我却觉得很多技术自己用的得心应手了自然就有了味道. 总结大家对 Cookie "食之无味" 大概有以下几个原因. (1). 不安全, 这是最直接的一个原因, 因为 Cookie 是保存在客户端计算机上的, 因此很容易被修改, 从而导致访问服务器时应用程序的执行失败或者其他安全问题. (2). 严重限制传送内容的大小, 这是最实现的一个原因, 大多数浏览器都限制 Cookie 的大小, 一般情况下都不能超过 4096 个字节, 因此传送的内容有限. (3). 用户可控制 Cookie 的开启与停用: 这是最无奈的一个原因, 当用户设置其浏览器停止接收 Cookie时, 如此, 它便失去了作用. (4). ....... 虽已为鸡肋,但弃之总会可惜, 原因也无非下列几个原由. (1). 使用简单: 因为使用太简单了, 所以它能活至今日, 虽有不少人一边天天抱怨, 一边却又偷偷地用它. Cookie 的简单是源于它是最简单的 索引键值 的文本结构, 读取与设置数据非常方便. (2). 不占用任何服务器资源: Cookie 的生成原理是由服务器创建后随网页一起输入到客户端, 并且在驻留在客户端计算机上, 因此不需要占用服务器的任何资源. (3). 有效期限可随意设置: 随心所欲地设置有效期限使它相当好用, 可以设置当浏览器结束访问时, Cookie 随之消失, 或者设置某个特点的到期时间, 甚至是永久保存在计算机上. (4). ....... OK, 是福是祸, 人各有志, 暂且放下不谈. 这里我总结出了 Cookie 在网页设计中各个方面所起的作用和使用方法. 还是那句话, 可能不是最全的, 但一定是最实用的. 与大家分享. 好, 这里就从最简单的使用开始. 1. Cookie 可以存储哪些值 在 Cookie 中只能存储个人可识别信息. 个人可识别信息是指可以用来识别或联系用户的信息. 例如用户的姓名, 电子邮件, 家庭住址等. 必须强调的是, 这些可识别信息必须是非机密或重要信息. 2. 使用 Cookie 对象保存和读取客户端信息. 要存储一个 Cookie 变量, 可以通过 Response 对象的 Cookie 集合, 语法如下: Response.Cookies[varName].Value=值; 其中, varName 为变量名. 要取回 Cookie, 可以使用 Request 对象的 Cookie 集合, 并将指定的 Cookie 集合返回, 语法如下 : 变量名=Request.Cookies[varName].Value; 以例为例: 用 Cookie 操作客户端 IP. 代码如下: //保存客户端信息 string UserIP = Request.UserHostAddress.ToString();//获取客户端的IP地址 Response.Cookies["IP"].Value = UserIP;//将客户端的IP地址保存在Cookies对象中 Response.Cookies["IP"].Expires = DateTime.MaxValue;//设计Cookies的失效期 //读取 Response.Write(Request.Cookies["IP"].Value);//从Cookies中读取客户端IP地址值 3. 加密 Cookie 中的数据 为了避免用户信息被他人窃取, 增强网站的安全性, 通常需要对 Cookie 中的数据进行加密, 加密代码如下: string data = "对Cookie中的数据加密。"; Response.Cookies["data"].Value = FormsAuthentication.HashPasswordForStoringInConfigFile(data, "md5"); Response.Write(Request.Cookies["data"].Value); 4. 使用 Cookie 对象在页面之间传值. 使用 Cookie 对象在页面之间传值与使用 Session 对象在页面之间传值的方法一样, 但两者有本质区别. 即Cookie 是存放在客户端的, 而 Session 是存放在服务器端的. Cookie 在使用时, 还需要配合 Asp.net 内置对象 Request. 使用 Cookie 对象传送信息的代码如下: if (txtName.Text == "A" && txtPassword.Text == "a") { HttpCookie newCookie = new HttpCookie("UserName"); newCookie.Value = txtName.Text.Trim(); Response.AppendCookie(newCookie); Server.Transfer("B.aspx"); } else { Response.Write("<script>alert('登录失败!');</script>"); } 在 目标页面 (B.aspx)中, 接收 Cookie 对象传来的值, 并将其显示在界面上, 代码如下: Label1.Text = Request.Cookies["UserName"].Value.ToString(); 5. 使用 Cookie 验证用户登录. 使用 Cookie 来验证用户登录, 首先需要将登录信息保存在 Cookie 对象中, 然后读取并验证. 以例为例, 当用户注册时 ( 当然很多情况下也可以是用户退出系统 ), 将用户和用户密码保存在 Cookie 对象中, 代码如下: Response.Cookies["SavedLogin"]["UserName"] =txtName.Text.Trim(); Response.Cookies["SavedLogin"]["UserPwd"] = txtPassword.Text.Trim(); Response.Cookies["SavedLogin"].Expires = DateTime.Now.AddDays(1); Response.Write("<script>alert('注册成功!');location='Default.aspx';</script>"); 而当用户登录时, 首先判断 Cookie 对象是否失效, 如果没有失效, 则判断用户输入的信息与 Cookie 对象中保存的信息是否一致, 如果一致, 就进行其他操作. 代码如下: if (Request.Cookies["SavedLogin"] == null) { Response.Write("<script>alert('Cookie 失效!');location='Default.aspx';</script>"); } else { if (txtName.Text == Request.Cookies["SavedLogin"] ["UserName"].ToString() && txtPassword.Text == Request.Cookies["SavedLogin"]["UserPwd"].ToString()) { Session["UserName"] = txtName.Text.Trim(); Response.Redirect("NavigatePage.aspx"); } else { Response.Write("<script>alert('登录失败!')"); } } 6. 创建及存取多个键值的 Cookie 对象. 多键值的应用其实是一种 "分类" 思想, 把某一类信息存储在一起. 实现方法是 使用 Response 对象可以创建多个数据值的 Cookie, 语法如下: Response.Cookies["CookieName"]["KeyName"]="Cookie中相对索引键的值"; 例如, 使用多键值保存用户名与密码. 代码如下: if (txtName.Text == "A" && txtPassword.Text == "a") { Response.Cookies["UserInfo"]["UserName"] = this.txtName.Text.Trim(); Response.Cookies["UserInfo"]["UserPwd"] = this.txtPassword.Text.Trim(); Response.Redirect("B.aspx"); } else { Response.Write("<script>alert('登录失败!');</script>"); } 当发出网页请求时, 浏览器会将 Cookie 信息发送到服务器. 在服务器端, 可以使用 Request 对象来存取 Cookie中的数据值. 语法格式有以下3种形式. 方法一: 直接取出数据值 |