cookie和session辨析

一、cookie是什么

cookie就是服务器发给客户端的信息,这些信息以文本文件的方式储存在诸如浏览器等的客户端里。然后,如果客户端再向相同域名的服务端发送请求的时候,就会带上这些信息。从服务端发送过来的cookie会出现在http的响应头中(response header),而当客户端再次向相同域名发送http请求的时候,cookie会出现在请求头中。

cookie经常用来存放用户的身份、密码等信息,最常见的cookie使用场景就是:在登陆界面,有一个“是否记住我”的选项,当勾选以后每户发送请求都会带上cookie来验证用户身份,这样用户就避免了重复输入用户名和密码了。

对于设置cookie,不同的语言有不同的方法,甚至还有一些专门的插件。当在一个域名下设置了cookie,之后针对这个域名和路径下所有的请求都会带上cookie。

关于cookie的过期时间:cookie的过期时间在与cookie的值一同设定的,它指定了cookie什么时候不再被发送至服务器,而后浏览器/服务端会删除该cookie。如果不设置的话,那么cookie只存在于当前会话当中,浏览器一旦关闭,该cookie就会被删除。P.S 但是chrome做了优化,在你关闭以后一点时间它依然不会失效。

关于cookie的域名和路径:域名(domain)选项决定了cookie被发送到哪个域名下,默认情况下是与创建cookie相同的域名;路径(path)的作用与域名选项相同,也是指定了特定的路径,才会在请求头中附加cookie信息。

登陆界面是否记住我的逻辑:当用户输入完用户名和密码以后,并且还勾选记住我的情况下,这些信息发送到服务端,在服务端完成用户验证以后,服务端会在setCookie里做一个不用重复输入密码的标记,然后发送给客户端,用户下次再登陆的时候,在这个域名和路径下,这些cookie会再次发送到服务端,服务端从cookie里读取了之前的标记,就不会让用户再次输入用户名和密码,而是直接跳转了。当然,这个cookie的标记是有时间限制的,一旦超过了,这个标记就会被浏览器删除。

总结:一般cookie交互过程如下:
1、客户端发送一个http请求给服务端
2、服务端发送一个http响应给客户端,在响应头中内嵌了cookie
3、在相同域名和相同路径下,客户端发送一个请求到服务端,在请求头中带上了cookie
4、服务端发回一个http响应给客户端

二、session是什么?

session的主要用处和cookie一样,都是用来记录用户的身份信息。不同的地方在于,cookie是储存在客户端,而session是储存在服务端。

因为cookie是储存在客户端,这就引发了一个安全问题:所有储存在客户端的东西都可以通过某种方式进行人为修改。而session则解决了这一问题,因为它储存在服务器上。

session的使用逻辑:服务器先给每一个发送过来http请求的浏览器一个id,当然,这个id是加密过的;这个id会储存在浏览器的cookie中,所以以后浏览器发送请求的时候都会带上这个cookie中的id。与此同时,服务器给每个用户给了一个session,当服务器验证通过了用户的身份信息,就会用session[id]在session中做一个标记,这样下次用户再在相同域名/路径请求时,服务器在读取到id并在session中找到了标记的话,用户就不用再次输入用户名和密码了。

三、Cookie and Session区别

1、cookie数据存放在客户的浏览器上,session数据放在服务器上;
2、cookie不是很安全,别人可以分析存放在本地的cookie并进行cookie欺骗,考虑到安全应当使用session;
3、session会在一定时间内保存在服务器上。当访问增多,会比较占用你服务器的性能。考虑到减轻服务器性能方面,应当使用cookie;
4、单个cookie在客户端的限制是4K,就是说一个站点在客户端存放的cookie不能超过4K

知乎上冯罗特的回答:

1,session 在服务器端,cookie 在客户端(浏览器)
2,session 默认被存在在服务器的一个文件里(不是内存)
3,session 的运行依赖 session id,而 session id 是存在 cookie 中的,也就是说,如果浏览器禁用了 cookie ,同时 session 也会失效(但是可以通过其它方式实现,比如在 url 中传递 session_id)
4,session 可以放在 文件、数据库、或内存中都可以。
5,用户验证这种场合一般会用 session 因此,维持一个会话的核心就是客户端的唯一标识,即 session id

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,616评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,020评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,078评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,040评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,154评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,265评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,298评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,072评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,491评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,795评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,970评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,654评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,272评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,985评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,815评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,852评论 2 351

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • http协议有http0.9,http1.0,http1.1和http2三个版本,但是现在浏览器使用的是htt...
    一现_阅读 1,858评论 0 3
  • 作者:晚晴幽草轩www.jeffjade.com/2016/10/31/115-summary-of-cookie...
    饥人谷_Dylan阅读 1,224评论 0 51
  • 2016年是参加向组织揩油的第二年,从2015年的懵懂到2016年的略微有眉目,掉了不少坑,当然,这些都会成为17...
    Andy熙阅读 240评论 2 2
  • 有人说,请磨去棱角,学会圆润,尽量合群!收敛个性,避免乖张! 那么,请问,如果所有人在步入社会中都这样去做,那是不...
    冽殇阅读 201评论 0 0