1.domain表示的是cookie所在的域,默认为请求的地址,如网址为www.jb51.net/test/test.aspx,那么domain默认为www.jb51.net。而跨域访问,如域A为t1.test.com,域B为t2.test.com,那么在域A生产一个令域A和域B都能访问的cookie就要将该cookie的domain设置为.test.com;若是要在域A生产一个令域A不能访问而域B能访问的cookie就要将该cookie的domain设置为t2.test.com。前端
2.path表示cookie所在的目录,asp.net默认为/,就是根目录。在同一个服务器上有目录以下:/test/,/test/cd/,/test/dd/,现设一个cookie1的path为/test/,cookie2的path为/test/cd/,那么test下的全部页面均可以访问到cookie1,而/test/和/test/dd/的子页面不能访问cookie2。这是由于cookie能让其path路径下的页面访问。ajax
3.浏览器会将domain和path都相同的cookie保存在一个文件里,cookie间用*隔开。后端
4.含值键值对的cookie:之前一直用的是nam=value单键值对的cookie,一说到含多个子键值对的就蒙了。如今总算弄清楚了。含多个子键值对的cookie格式是name=key1=value1&key2=value2。能够理解为单键值对的值保存一个自定义的多键值字符串,其中的键值对分割符为&,固然能够自定义一个分隔符,但用asp.net获取时是以&为分割符。跨域
5,须要提的是,只有匹配path,而且符合domain,才会在请求时带上cookie。浏览器
另外说点应用之处:服务器
在一些前端应用中,后端生成登陆态存储到cookie中(response setCookie),在之后的请求中,都会在request cookie中带着。来证实是否登陆。这里面须要注意的是:cookie
一,该cookie是由后端注入;前端不用操做;asp.net
二,若是请求是ajax请求,请注意设置属性 withCredentials: true (支持跨域发送cookies)。dom