共计 1049 个字符,预计需要花费 3 分钟才能阅读完成。
Cookie 为 Web 应用程序保存用户相关信息提供了一种有用的方法。例如,当用户访问站点时,可以利用 Cookie 保存用户首选项或其他信息,这样,当用户下次再访问站点时,应用程序就可以检索以前保存的信息。其存储在客户端,存放的是 string 类型的数据。
1.Cookie 的创建
1 HttpCookie cookie = new HttpCookie("myCookie");
2 cookie.Values.Add("No", userName);
3 cookie.Values.Add("Name", HttpUtility.UrlEncode(userService.GetUser(userName).Name));
4 cookie.Values.Add("Pass", password);
5 cookie.Values.Add("SID", System.Web.HttpContext.Current.Session.SessionID);
6 // 设置过期时间
7 cookie.Expires = DateTime.Now.AddDays(5);
8 System.Web.HttpContext.Current.Response.AppendCookie(cookie);
2. 删除 Cookie
1 // 删除 Cookie
2 HttpCookie mycookie = new HttpCookie("myCookie");
3 mycookie.Expires = DateTime.Now.AddDays(-1);
4 Response.Cookies.Add(mycookie);
3. 总结
Cookie 虽然是一个简单实用的对象,但是我们也要注意 Cookie 的工作原理、大小限制以及安全性等,大致可以归纳为以下几点。
- 存储的物理位置。客户端的 Cookies 文件夹内。
- 存储的类型限制。字符串。
- 状态使用的范围。当前请求上下文的上下文都能访问到 Cookie,Cookie 对每个用户来说都是独立的。
- 存储的大小限制。每个 Cookie 不超过 4K 数据。每个网站不超过 20 个 Cookie。所有网站的 Cookie 总和不超过 300 个。
- 生命周期。每个 Cookie 都有自己的过期时间,超过了过期时间后失效。
- 安全与性能。存储在客户端,安全性差。对于敏感数据建议加密后存储。
- 优点缺点与注意事项。可以很方便地关联网站和用户,长久保存用户设置。
本文永久更新链接地址 :http://www.linuxidc.com/Linux/2015-08/121308.htm
正文完
星哥玩云-微信公众号