Cookie、Session和Token

      我们都知道Session和Cookie的区别就是Session是存储在服务端的,Cookie是存储在浏览器上的。


Cookie技术产生源于HTTP协议在互联网上的急速发展,复杂的互联网交互活动,就必须让服务器保持活动状态。Cookie在计算机中是个存储在浏览器目录中的文本文件,当浏览器运行时,存储在RAM中发挥作用(Session cookie),一旦用户从该网站或服务器退出,Cookie可以存储在用户本地磁盘上(persistent cookie)。cookie有时效性和使用限制。

Cookie的是为了让无状态的HTTP报文带上一些特殊的数据,让服务端能够辨识请求的身份。简单的说“cookie就是浏览器上的一个key-value存储对象”。

写入数据:Cookie写入数据的方式通过HTTP返回报文的Header部分Set-Cookie字段来设置。

获取数据:浏览器在发送请求时会检查当前域已经设置的Cookie,在HTTP请求报文Header部分的Cookie字段里带上Cookie的信息。


Session是对服务端来说的,客户端没有Session这一说法,Session是服务器在客户端建立连接时添加客户连接标志,最终会在服务器软件(Apache、Tomcat、JBoss)转换为一个临时Cookie发送给客户端,当客户端第一次请求时服务器会检查是否携带了这个Session(临时Cookie)如果没有则会添加Session,如果有就拿出这个Session来左相关操作。Session就是在一次会话中解决两次HTTP的请求的关联,让两个页面都能读取到这个全局的Session信息。同时Session的信息存在于服务端,很好的解决了安全问题。

Session是记录客户端状态的一个存储对象,是同一个客户端请求共享数据的数组。这个存储对象可以是文件、缓存系统、数据库。假设用redis来实现Session的功能,那么要求浏览器每次请求都要带一个相同的字符串作为身份信息,对应redis的key,redis value则为Session数组的序列化内容。

浏览器请求:如何让浏览器每次请求都带一个身份信息,这就是Session和Cookie的关系,通过Cookie传递这个身份信息。

     1.客户端求。2.服务端检查Header,发现没有Cookie,于是生成一个UUID。3.服务端处理数据,把部分数据(登录信息)存储到redis里,UUID为key,用户id为value       

4.返回报文中,增加Set-Cookie字段,把UUID写进浏览器存储里面。 5.浏览器收到报文,把UUID写进浏览器存储里面。                                                                   

6.浏览器再次请求,带上当前的域的Cookie,就是这个UUID。7.服务端通过Cookie字段取到UUUID,去redis里面获取用户信息。

流程图

禁止Cookie获取Session

从前面知道,Sessionid是通过Cookie来传递的,如果Cookie禁止了,还能获取Sessionid吗?其实是可以的,即使Cookie禁止了,可以使用参数的方法传递Sessionid,后端返回的时候,增加一个返回参数,叫Sessionid,然后前端存储到localstorage里。

前端请求的时候,去localstorage中获取Sessionid,在请求参数里增加一个参数。

后端session处理,先尝试去Cookie中获取Sessionid,如果获取不到,再尝试去请求参数中获取Sessionid。


Token:

Token是用户的身份验证方式,通常叫“令牌”。最简单的Token组成:uid、time、sign。还可以把不变的参数放进Token

应用:

A:用户首次登录成功(注册也一样)后,服务端就会产生一个Token值,这个值会在服务器中保存Token值,再将这个值返回给客户端。

B:客户端拿到Token值之后,进行本地保存。  

C:当客户端再次发送请求,就会将这个token值附带到参数中发送给服务器。

D:服务器收到客户端的请求之后,会取出token值与保存在本地的token做对比。          


总结:

区别                                                                                                                                            *Cookie是浏览器端的存储对象,有容量限制,通过HTTP报文与后端交互。cookie不是很安全,别人可以分析放在本地的cookie进行欺骗,考虑到安全应当使用session。

*Session是服务端的存储对象,实现的方式可以有文件系统、缓存系统、数据库。session会在一定时间内保存在服务器上。当访问增多,会比较占用服务器的性能。

联系                                                                                                                                            *Session和Cookie都是为了实现HTTP请求带上的客户端状态的方法 

*Session大多数情况下都是依赖Cookie来传递Session ID  

*一般建议登录信息等重要信息保存在session中,其他信息放在cookie中 

*token和session并不矛盾,作为身份认证token安全性比session好,因为每一个请求都有签名还能防止监听以及重放攻击。

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

推荐阅读更多精彩内容

  • 前言 Web诞生之初,功能比较单一:允许Internet上任意一个用户都可以从许多文档服务计算机的数据库中搜索和获...
    赵客缦胡缨v吴钩霜雪明阅读 6,427评论 4 153
  • 1.背景介绍 由于HTTP是一种无状态协议,服务器没有办法单单从网络连接上面知道访问者的身份,为了解决这个问题,就...
    黑白电影_阅读 10,286评论 0 10
  • 一、Cookie   由于HTTP是一种无状态协议,每次请求时,例如需要登陆的界面如购物车界面,服务器没有办法单单...
    小盟城主阅读 3,223评论 0 7
  • 上周《第一财经周刊》发布了今年的新一线城市排名,对于各个城市的排名,大家应该并没有感到意外。四个一线城市的位置稳稳...
    马虎眼阅读 5,096评论 3 8
  • 十年风雨十年霜,旧了容颜旧春裳。 时光不曾缘客留,念旧亭处看他乡。 别去多少流年月,遗憾丛中几许伤。 人生路上多坎...
    云烟一客阅读 251评论 2 7