保留登陆信息方式的演进

简单讲讲三种主流的保存登陆信息的方式

本篇脱离框架,从基本思想上简述多种授权方式的区别。

首先,基于cookie和session的方式

先说一下cookie和session结合的方式(不去说纯cookie,可以被篡改,安全性太差)

  • cookie:存储与客户端的缓存,可以设置数据的过期时间,存储在内存中,会被清除。
  • session:同样类似于缓存,客户端与服务器的每次会话,都会存在一个session。识别session基于cookie。实现方式大概是:为一个访问者生成session时,给客户端一个id,这个id对应于这个session。

这种实现的逻辑,基本上就是把数据存于服务器。session保存于服务器,客户端无法直接访问。然后给客户端一把钥匙,客户端携带着这个钥匙,带给服务器,服务器拿着这个钥匙从session里找到客户的信息,然后予以认证。

  • 优点:简单,方便。目前的大多数框架都对session存在现有的集成与封装。
  • 缺点:最大的缺点是,如果大量用户同时保持登陆状态,服务端则需要存储大量session数据,服务器压力较大。

这种方式还存在其他的小问题,例如:服务器重启后,用户登陆信息消失,用户就需要重新登录;在分布式环境下,无法获取登陆信息;
但是也产生了其解决方案:比如说,存数据库的方式。在数据库的用户表留一个字段,需要找用户信息的时候去数据库找用户信息。再者就是通过redis的方式实现,跑一个redis数据服务器,用redis存session。既保证了应用服务器重启数据不消失,也支持了集群环境。
但是,专门找一台服务器存储用户的登陆信息,还是需要耗费大量的服务器资源。并且,如果应用本身并不需要redis,那为了session专门搭建redis服务,单独放一台服务器,也不太合适。所以JWT应需而生。

JWT,无状态登陆信息

  • 思路其实跟session+cookie的方式如出一辙,都是客户端带令牌,服务器来负责通过你的令牌读取你的个人信息。但是JWT不需要服务器存储客户端的信息,而是把用户信息加密到令牌上。然后服务器就不存放用户信息了,但是你的令牌必须通过服务器的加密字段才能解密。客户端存放的令牌上保存着用户的信息,以及令牌过期时间等。
  • 生活中举例子就是:给你发了一张身份证,身份证上是一个二维码。二维码里是你的身份信息,以及身份证过期时间。但是只有警方才有扫描你二维码的设备,你本人是没有的。在你买火车票,飞机票,以及办理护照的时候,把这个二维码给相应的人员,他们扫码获取到你的个人信息,并验证没过期就为你办理。如果过期了,就要求你去重新办理一张新的二维码身份证。

这种方式解决的最大的问题就是,服务器不需要存储你的个人信息了。在用户量巨大的情况下,这种方式节省了大量的服务器开支(尤其是部分用户的登陆状态需要保持一个月之久,对服务器来说无疑是巨大的资源消耗)。另外,这种方式也更简单,不需要跟redis进行交互,也不需要跟关系型数据库进行交互。服务器唯一要做的事就是,根据你的JWT解密拿取你得个人信息。

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

推荐阅读更多精彩内容