一文彻底理解CookieSessionToken
很久很久以前,Web基本上就是文档的浏览而已,既然是浏览,作为服务器,不需要记录谁在某一段时间里都浏览了什么文档,每次请求都是一个新的HTTP协议,就是请求加响应,尤其是我不用记住是谁刚刚发了HTTP请求,每个请求对我来说都是全新的。这段时间很嗨皮。
但是随着交互式Web应用的兴起,像在线购物网站,需要登录的网站等等,马上就面临一个问题,那就是要管理会话,必须记住哪些人登录系统,哪些人往自己的购物车中放商品,也就是说我必须把每个人区分开,这就是一个不小的挑战,因为HTTP请求是无状态的,所以想出的办法就是给大家发一个会话标识(sessionid),说白了就是一个随机的字串,每个人收到的都不一样,每次大家向我发起HTTP请求的时候,把这个字符串给一并捎过来,这样我就能区分开谁是谁了。
这样大家很嗨皮了,可是服务器就不嗨皮了,每个人只需要保存自己的sessionid,而服务器要保存所有人的sessionid!如果访问服务器多了,就得由成千上万,甚至几十万个。
这对服务器说是一个巨大的开销,严重的限制了服务器扩展能力,比如说我用两个机器组成了一个集群,小F通过机器A登录了系统,那sessionid会保存在机器A上,假设小F的下一次请求被转发到机器B怎么办?机器B可没有小F的sessionid啊。
有时候会采用一点小伎俩:sessionsticky,就是让小F的请求一直粘连在机器A上,但是这也不管用,要是机器A挂掉了,还得转到机器B去。
那只好做session的复制了,把sessionid在两个机器之间搬来搬去,快累死了。
后来有个叫Memcached的支了招:把sessionid集中存储到一个地方,所有的机器都来访问这个地方的数据,这样一来,就不用复制了,但是增加了单点失败的可能性,要是那个负责session的机器挂了,所有人都得重新登录一遍,估计得被人骂死。
也尝试把这个单点的机器也搞出集群,增加可靠性,但不管如何,这小小的session对我来说是一个沉重的负担
于是有人就一直在思考,我为什么要保存这可恶的session呢,只让每个客户端去保存该多好?
可是如果不保存这些sessionid,怎么验证客户端发给我的sessionid的确是我生成的呢?如果不去验证,我们都不知道他们是不是合法登录的用户,那些不怀好意的家伙们就可以伪造sessionid,为所欲为了。
嗯,对了,关键点就是验证!
比如说,小F已经登录了系统,我给他发一个令牌(token),里边包含了小F的userid,下一次小F再次通过Http请求访问我的时候,把这个token通过Httpheader带过来不就可以了。
不过这和sessionid没有本质区别啊,任何人都可以可以伪造,所以我得想点儿办法,让别人伪造不了。
那就对数据做一个签名吧,比如说我用HMACSHA256算法,加上一个只有我才知道的密钥,对数据做一个签名,把这个签名和数据一起作为token,由于密钥别人不知道,就无法伪造token了。
这个token我不保存,当小F把这个token给我发过来的时候,我再用同样的HMACSHA256算法和同样的密钥,对数据再计算一次签名,和token中的签名做个比较,如果相同,我就知道小F已经登录过了,并且可以直接取到小F的userid,如果不相同,数据部分肯定被人篡改过,我就告诉发送者:对不起,没有认证。
Token中的数据是明文保存的(虽然我会用Base64做下编码,但那不是加密),还是可以被别人看到的,所以我不能在其中保存像密码这样的敏感信息。
当然,如果一个人的token被别人偷走了,那我也没办法,我也会认为小偷就是合法用户,这其实和一个人的sessionid被别人偷走是一样的。
这样一来,我就不保存sessionid了,我只是生成token,然后验证token,我用我的CPU计算时间获取了我的session存储空间!
解除了sessionid这个负担,可以说是无事一身轻,我的机器集群现在可以轻松地做水平扩展,用户访问量增大,直接加机器就行。这种无状态的感觉实在是太好了!
Cookie是一个非常具体的东西,指的就是浏览器里面能永久存储的一种数据,仅仅是浏览器实现的一种数据存储功能。
Cookie由服务器生成,发送给浏览器,浏览器把cookie以kv形式保存到某个目录下的文本文件内,下一次请求同一网站时会把该cookie发送给服务器。由于cookie是存在客户端上的,所以浏览器加入了一些限制确保cookie不会被恶意使用,同时不会占据太多磁盘空间,所以每个域的cookie数量是有限的。
Session从字面上讲,就是会话。这个就类似于你和一个人交谈,你怎么知道当前和你交谈的是张三而不是李四呢?对方肯定有某种特征(长相等)表明他就是张三。
Session也是类似的道理,服务器要知道当前发请求给自己的是谁。为了做这种区分,服务器就要给每个客户端分配不同的身份标识,然后客户端每次向服务器发请求的时候,都带上这个身份标识,服务器就知道这个请求来自于谁了。至于客户端怎么保存这个身份标识,可以有很多种方式,对于浏览器客户端,大家都默认采用cookie的方式。
服务器使用session把用户的信息临时保存在了服务器上,用户离开网站后session会被销毁。这种用户信息存储方式相对cookie来说更安全,可是session有一个缺陷:如果web服务器做了负载均衡,那么下一个操作请求到了另一台服务器的时候session会丢失。
在基于Session的身份验证中,服务器将在用户登录后为用户创建一个Session。然后,SessionID会被存储在用户浏览器的Cookie中。当用户保持登录状态时,Cookie将与每个后续请求一起被发送出去。然后,服务器可以将存储在Cookie上的SessionID与存储在内存中或者数据库中的Session信息进行比较,以验证用户的身份,返回给用户客户端响应信息的时候会附带用户当前的状态。
对照下面的示意图应该更容易理解。
在Web领域基于Token的身份验证随处可见。在大多数使用WebAPI的互联网公司中,tokens是多用户下处理认证的最佳方式。
大部分你见到过的API和Web应用都使用tokens。例如Facebook,Twitter,Google,GitHub等。
以下几点特性会让你在程序中使用基于Token的身份验证:无状态、可扩展支持移动设备跨程序调用安全
在介绍基于Token的身份验证的原理与优势之前,不妨先看看之前的认证都是怎么做的。
基于服务器的验证:
我们都是知道HTTP协议是无状态的,这种无状态意味着程序需要验证每一次请求,从而辨别客户端的身份。
在这之前,程序都是通过在服务端存储的登录信息来辨别请求的。这种方式一般都是通过存储Session来完成。
随着Web,应用程序,已经移动端的兴起,这种验证的方式逐渐暴露出了问题。尤其是在可扩展性方面。
基于服务器验证方式暴露的一些问题:
1。Seesion:每次认证用户发起请求时,服务器需要去创建一个记录来存储信息。当越来越多的用户发请求时,内存的开销也会不断增加。
2。可扩展性:在服务端的内存中使用Seesion存储登录信息,伴随而来的是可扩展性问题。
3。CORS(跨域资源共享):当我们需要让数据跨多台移动设备上使用时,跨域资源的共享会是一个让人头疼的问题。在使用Ajax抓取另一个域的资源,就可以会出现禁止请求的情况。
4。CSRF(跨站请求伪造):用户在访问银行网站时,他们很容易受到跨站请求伪造的攻击,并且能够被利用其访问其他的网站。
在这些问题中,可扩展行是最突出的。因此我们有必要去寻求一种更有行之有效的方法。
基于Token的身份验证是无状态的,我们不将用户信息存在服务器或Session中。
这种概念解决了在服务端存储信息时的许多问题。NoSession意味着你的程序可以根据需要去增减机器,而不用去担心用户是否登录。
基于Token的身份验证的过程如下:用户通过用户名和密码发送请求。程序验证。程序返回一个签名的token给客户端。客户端储存token,并且每次用于每次发送请求。服务端验证token并返回数据。
每一次请求都需要token。token应该在HTTP的头部发送从而保证了Http请求无状态。我们同样通过设置服务器属性AccessControlAllowOrigin:,让服务器能接受到来自所有域的请求。需要主要的是,在ACAO头部标明(designating)时,不得带有像HTTP认证,客户端SSL证书和cookies的证书。
实现思路:
5。用户登录校验,校验成功后就返回Token给客户端。
6。客户端收到数据后保存在客户端。
7。客户端每次访问API是携带Token到服务器端。
8。服务器端采用filter过滤器校验。校验成功则返回请求数据,校验失败则返回错误码。
当我们在程序中认证了信息并取得token之后,我们便能通过这个Token做许多的事情。
我们甚至能基于创建一个基于权限的token传给第三方应用程序,这些第三方程序能够获取到我们的数据(当然只有在我们允许的特定的token)
无状态、可扩展
在客户端存储的Token是无状态的,并且能够被扩展。基于这种无状态和不存储Session信息,负载负载均衡器能够将用户信息从一个服务传到其他服务器上。
如果我们将已验证的用户的信息保存在Session中,则每次请求都需要用户向已验证的服务器发送验证信息(称为Session亲和性)。用户量大时,可能会造成一些拥堵。
但是不要着急。使用Token之后这些问题都迎刃而解,因为Token自己hold住了用户的验证信息。
安全性
请求中发送token而不再是发送cookie能够防止CSRF(跨站请求伪造)。即使在客户端使用cookie存储token,cookie也仅仅是一个存储机制而不是用于认证。不将信息存储在Session中,让我们少了对session操作。
Token是有时效的,一段时间之后用户需要重新验证。我们也不一定需要等到Token自动失效,Token有撤回的操作,通过tokenrevocataion可以使一个特定的Token或是一组有相同认证的token无效。
可扩展性
Token能够创建与其它程序共享权限的程序。例如,能将一个随便的社交帐号和自己的大号(Fackbook或是Twitter)联系起来。当通过服务登录Twitter(我们将这个过程Buffer)时,我们可以将这些Buffer附到Twitter的数据流上(weareallowingBuffertoposttoourTwitterstream)。
使用Token时,可以提供可选的权限给第三方应用程序。当用户想让另一个应用程序访问它们的数据,我们可以通过建立自己的API,得出特殊权限的tokens。
多平台跨域
我们提前先来谈论一下CORS(跨域资源共享),对应用程序和服务进行扩展的时候,需要介入各种各种的设备和应用程序。
HavingourAPIjustservedata,wecanalsomakethedesignchoicetoserveassetsfromaCDN。ThiseliminatestheissuesthatCORSbringsupafterwesetaquickheaderconfigurationforourapplication。
只要用户有一个通过了验证的token,数据和资源就能够在任何域上被请求到。
基于标准
创建Token的时候,你可以设定一些选项。我们在后续的文章中会进行更加详尽的描述,但是标准的用法会在JSONWebToken体现。
最近的程序和文档是供给JSONWebToken的。它支持众多的语言。这意味在未来的使用中你可以真正的转换你的认证机制。(end)
315揭秘美容仪质量陷阱,几乎人手一台的它真有那么香?都说好看的皮囊千篇一律,有趣的灵魂万里挑一。可问题是:有趣的灵魂是需要大量时间才能发觉,我们对于他人的第一印象大都还是始于外貌啊!而当我们想要变美时,除了护肤品和彩妆外,各种美……
拒广第12期(新的一季,再接再厉!!!辣妹高上一季度,咱们是自断了75条财路,继续勇攀高峰。红球遮瑕00粉橘色。原本对这只联名款,充满期待,结果遮不住扒不牢脱得快。遮瑕容易出现的问题,你小子全犯。粉橘色00(黑眼……
近2。7万名游客赴黄鹤楼花朝盛宴共享春日浪漫极目新闻记者李辉通讯员江萌视频剪辑李辉黄鹤楼前,人们沉浸在花朝节盛宴中。极目新闻记者李辉摄黄鹤楼前,人们沉浸在花朝节盛宴中。极目新闻记者李辉摄20……
当春天的脚步尾声云衡微语当春天的脚步渐行渐远珠穆朗玛的雪山已是莺歌燕舞当夏天的石板拷打我们的汗水禾苗开始它的根深叶茂或许耕耘播种我不在现场或许春暖花开我在窗……
奇瑞电动小车,QQ冰淇淋新车型上市,续航170公里,售价3。在五菱宏光MINIEV成为爆款之后,很多其他品牌也纷纷推出了与之对标的车型,奇瑞QQ冰淇淋就是其中之一,上市后也有着不错的市场表现。为了进一步提升竞争力,4月9日,奇瑞推……
检查作业时间到了!让我借你一双慧眼把CBA看的清清楚楚明明白头条创作挑战赛这个本赛季CBA前瞻的作业是去年赛季开始前所做,具体时间是2022。10。5日,现在就让我们一起来检查一下!精彩开始干什么都要格局打开!所以让我……
不结婚也想穿的婚纱,长啥样?婚纱攻略风格灵感大家好呀,我是洺亦。上两周和大家分享了貌美又实用的婚包,那今天我们就来聊聊备婚清单上的重头戏婚纱KIMKASSAS婚纱系列OhRomeo图片来源:KIMKAS……
潮流时尚,新鲜速递2倒钩AJ1刚完结,鞋王就有新宠?近期相信有不少小伙伴,都被最后一双倒钩AJ1,吊足了胃口。难道始作俑者TravisScott,这么快就有新目标了?很可惜,答案……
夏天对女生来说,到底有多抓狂?漫画揭晓直男你或许不懂每当到了炎热夏季,女孩都会画上清凉的小裙子,这也让很多男生心里特别羡慕,仅能够让自己维持美丽的外观,还能够做到特别凉爽的情况。在他们心当中,女孩子穿裙子一定很舒服,也能够……
与人在交往中,这四种人,比小人更可怕,一定要警惕人从出生的那一刻起,就决定他将成为一个独立的个体。这种独立不仅是外在的表现,也是内在精神世界的总结。我们常说,没有两个完全一样的人,由于成长环境与个人性格的不同,每个人都或多或……
类风湿类风湿除了吃药还能做些什么?副主任医师郭志。显关节炎除了吃药还能做什么?注意控制病情以外,还要注意以下几点:第一,需要保持良好的心态。类风湿关节炎是有一个比较高的致残率的……
切勿签订阴阳合同湖南省消保委提醒你买二手房注意这些事随着我省《关于打好经济增长主动仗实现经济运行整体好转的若干政策措施》的出台,以及一些地方购房政策的调整,我省二手房交易市场成交量放大。为使消费者对二手房交易有更全面的了解,科学……