细说Cookie
细说Cookie 说这话我就有点点狂了 我只说说我的理解 外加网上整理的 不足之处还请大家指教1 现在网站可以没有cookie吗?
Cookie虽然是个很简单的东西 但它又是WEB开发中一个很重要的客户端数据来源 而且它可以实现扩展性很好的会话状态
所以我认为每个WEB开发人员都有必要对它有个清晰的认识
Cookie 概述
Cookie是什么?
Cookie 是一小段文本信息 伴随着用户请求和页面在 Web 服务器和浏览器之间传递 Cookie 包含每次用户访问站点时 Web 应用程序都可以读取的信息
为什么需要Cookie?
因为HTTP协议是无状态的 对于一个浏览器发出的多次请求 WEB服务器无法区分 是不是来源于同一个浏览器 所以 要额外的数据用于维护会话 ookie 正是这样的一段随HTTP请求一起被传递的额外数据
Cookie能做什么?
Cookie只是一段文本 以它只能保存字符串 且浏览器对它有大小限制以及 它会随着每次请求被发送到服务器 以应该保证它不要太大 cookie的内容也是明文保存的 些浏览器提供界面修改 所以 不适合保存重要的或者涉及隐私的内容
Cookie 的限制
大多数浏览器支持最大为 4096 字节的 Cookie 由于这限制了 Cookie 的大小 最好用 Cookie 来存储少量数据 或者存储用户 ID 之类的标识符 用户 ID 随后便可用于标识用户,以及从数据库或其他数据源中读取用户信息 浏览器还限制站点可以在用户计算机上存储的 Cookie 的数量 大多数浏览器只允许每个站点存储 20 个 Cookie;如果试图存储更多 Cookie 则最旧的 Cookie 便会被丢弃 有些浏览器还会对它们将接受的来自所有站点的 Cookie 总数作出绝对限制 通常为 300 个
Cookie的写、读过程
哈哈 这个不用多说了 大家心知肚明 来一段DEMO
在中,读写Cookie是通过使用HttpCookie类来完成的,它的定义如下:
程序代码:
public sealed class HttpCookie { // 获取或设置将此 Cookie 与其关联的域。默认值为当前域。 public string Domain { get; set; } // 获取或设置此 Cookie 的过期日期和时间(在客户端)。 public DateTime Expires { get; set; } // 获取一个值,通过该值指示 Cookie 是否具有子键。 public bool HasKeys { get; } // 获取或设置一个值,该值指定 Cookie 是否可通过客户端脚本访问。 // 如果 Cookie 具有 HttpOnly 属性且不能通过客户端脚本访问,则为 true;否则为 false。默认为 false。 public bool HttpOnly { get; set; } // 获取或设置 Cookie 的名称。 public string Name { get; set; } // 获取或设置要与当前 Cookie 一起传输的虚拟路径。默认值为当前请求的路径。 public string Path { get; set; } // 获取或设置一个值,该值指示是否使用安全套接字层 (SSL)(即仅通过 HTTPS)传输 Cookie。 public bool Secure { get; set; } // 获取或设置单个 Cookie 值。默认值为空引用。 public string Value { get; set; } // 获取单个 Cookie 对象所包含的键值对的集合。 public NameValueCollection Values { get; } // 获取 System.Web.HttpCookie.Values 属性的快捷方式。 public string this[string key] { get; set; } }Cookie写入浏览器的过程:我们可以使用如下代码在项目中写一个Cookie 并发送到客户端的浏览器(为了简单我没有设置其它属性)。
HttpCookie cookie = new HttpCookie("MyCookieName", "string value"); Response.Cookies.Add(cookie);
写到这里我想很多人都写过类似的代码,但是,大家有没有想过:Cookie最后是如何发送到客户端的呢?
这里引入Fiddler Fiddler可是个好东西啊 破站 入侵 POST数据 离不开这个 是居家旅行 杀站越货必备之物