当前位置:首页 > 网站建设 > 正文内容

htmljs简易聊天室模版(js聊天室代码)

网站建设3个月前 (10-26)308

来源:John Wu,

blog.leapoahead.com/2015/09/07/user-authentication-with-jwt/

来源:John Wu,

blog.leapoahead.com/2015/09/07/user-authentication-with-jwt/

上次在《》中我提到了JSON Web Token可以用来设计单点登录系统。我尝试用八幅漫画先让大家理解如何设计正常的用户认证系统,然后再延伸到单点登录系统。

如果还没有阅读《》,我强烈建议你花十分钟阅读它,理解JWT的生成过程和原理。

用户认证八步走

所谓用户认证(Authentication),就是让用户登录,并且在接下来的一段时间内让用户访问网站时可以使用其账户,而不需要再次登录的机制。

小知识:可别把用户认证和用户授权(Authorization)搞混了。用户授权指的是规定并允许用户使用自己的权限,例如发布帖子、管理站点等。

首先,服务器应用(下面简称“应用”)让用户通过Web表单将自己的用户名和密码发送到服务器的接口。这一过程一般是一个HTTP POST请求。建议的方式是通过SSL加密的传输(https协议),从而避免敏感信息被嗅探。

接下来,应用和数据库核对用户名和密码。

展开全文

核对用户名和密码成功后,应用将用户的id(图中的user_id)作为JWT Payload的一个属性,将其与头部分别进行编码拼接后签名,形成一个JWT。这里的JWT就是一个形同lll.zzz.xxx的字符串。

应用将JWT字符串作为该请求Cookie的一部分返回给用户。注意,在这里必须使用HttpOnly属性来防止Cookie被Java读取,从而避免跨站脚本攻击(XSS攻击)。

在Cookie失效或者被删除前,用户每次访问应用,应用都会接受到含有jwt的Cookie。从而应用就可以将JWT从请求中提取出来。

应用通过一系列任务检查JWT的有效性。例如,检查签名是否正确;检查Token是否过期;检查Token的接收方是否是自己(可选)。

应用在确认JWT有效之后,JWT进行解码(可能在上一步中已经完成),然后在Payload中读取用户的id值,也就是user_id属性。这里用户的id为1025。

应用从数据库取到id为1025的用户的信息,加载到内存中,进行ORM之类的一系列底层逻辑初始化。

应用根据用户请求进行响应。

和Session方式存储id的差异

Session方式存储用户id的最大弊病在于要占用大量服务器内存,对于较大型应用而言可能还要保存许多的状态。一般而言,大型应用还需要借助一些KV数据库和一系列缓存机制来实现Session的存储。

而JWT方式将用户状态分散到了客户端中,可以明显减轻服务端的内存压力。除了用户id之外,还可以存储其他的和用户相关的信息,例如该用户是否是管理员、用户所在的分桶(见[《你所应该知道的A/B测试基础》一文](/2015/08/27/introduction-to-ab-testing/)等。

htmljs简易聊天室模版(js聊天室代码)

虽说JWT方式让服务器有一些计算压力(例如加密、编码和解码),但是这些压力相比磁盘I/O而言或许是半斤八两。具体是否采用,需要在不同场景下用数据说话。

单点登录

Session方式来存储用户id,一开始用户的Session只会存储在一台服务器上。对于有多个子域名的站点,每个子域名至少会对应一台不同的服务器,例如:

www.taobao.com

nv.taobao.com

nz.taobao.com

login.taobao.com

www.taobao.com

nv.taobao.com

nz.taobao.com

login.taobao.com

所以如果要实现在login.taobao.com登录后,在其他的子域名下依然可以取到Session,这要求我们在多台服务器上同步Session。

使用JWT的方式则没有这个问题的存在,因为用户的状态已经被传送到了客户端。因此,我们只需要将含有JWT的Cookie的domain设置为顶级域名即可,例如

Set-Cookie: jwt=lll.zzz.xxx; HttpOnly; max-age=980000; domain=.taobao.com

Set-Cookie: jwt=lll.zzz.xxx; HttpOnly; max-age=980000; domain=.taobao.com

注意domain必须设置为一个点加顶级域名,即.taobao.com。这样,taobao.com和*.taobao.com就都可以接受到这个Cookie,并获取JWT了。

看完本文有收获?请转发分享给更多人

关注「ImportNew」,看技术干货

扫描二维码推送至手机访问。

版权声明:本文由飞速云SEO网络优化推广发布,如需转载请注明出处。

本文链接:http://zspsrg.cn/post/122967.html

分享给朋友:

“htmljs简易聊天室模版(js聊天室代码)” 的相关文章

上海网站排名优化(上海优化网站方法)

上海网站排名优化(上海优化网站方法)

本篇文章给大家谈谈上海网站排名优化,以及上海优化网站方法对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、上海网络百度seo优化排名推广找哪家公司可靠? 2、上海网站seo优化营销有什么好的技巧? 3、哪家网站百度排名上海优化推广公司靠谱? 4、上海市公司如何做...

熊猫办公ppt模板下载免费(熊猫办公ppt模板下载免费版)

熊猫办公ppt模板下载免费(熊猫办公ppt模板下载免费版)

今天给各位分享熊猫办公ppt模板下载免费的知识,其中也会对熊猫办公ppt模板下载免费版进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、谁有熊猫办公PPT的下载会员么,请帮下载一个PPT,感谢了! 2、跪求一个熊猫办公的ppt模板网站的vip的号,快到年底...

招生宣传单模板简洁(招生传单设计模板)

招生宣传单模板简洁(招生传单设计模板)

本篇文章给大家谈谈招生宣传单模板简洁,以及招生传单设计模板对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、宣传单模板 2、小学生辅导班招生宣传单怎么写? 3、小学生作文辅导班招生宣传单怎么写 4、英语培训班招生宣传单怎么做 5、开业宣传单怎么写 宣传单模...

QQ浏览器怎么查看源代码(浏览器查看网页源代码)

QQ浏览器怎么查看源代码(浏览器查看网页源代码)

今天给各位分享QQ浏览器怎么查看源代码的知识,其中也会对浏览器查看网页源代码进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、手机自带浏览器看一些比如腾讯朋友,搜搜之类的网页只能显示源代码, 2、电脑qq浏览器打不开了怎么办啊 3、怎么用es文件浏览器...

生日视频mv短片制作(宝宝生日视频mv短片制作)

生日视频mv短片制作(宝宝生日视频mv短片制作)

本篇文章给大家谈谈生日视频mv短片制作,以及宝宝生日视频mv短片制作对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。 本文目录一览: 1、怎样自己制作视频 2、婚礼视频制作软件哪个好 3、如何制作简单的视频 4、怎么样制作剪辑和怎么样截取视频短片? 5、怎么制作视频? 6、...

稿定设计如何导出H5(稿定设计如何导出)

稿定设计如何导出H5(稿定设计如何导出)

今天给各位分享稿定设计如何导出H5的知识,其中也会对稿定设计如何导出进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!本文目录一览: 1、方正飞翔h5作品怎么导出 2、稿定设计怎么分享链接 3、稿定设计在线PS好的图怎么下载到电脑上? 4、如何把整个ppt转h5...