.net 一个网站怎同一个用户登录只能登陆一次_一文带你了解现在的网站是如何做登录的...

ebcd60cdf28b76ee55a978f3f8334a26.png 此篇我想聊一聊单点登录。

在web初期时代,也就是servlet时代,我们知道,一个用户要在一个电商网站进行注册登陆,那么网站必须有一个数据库,用来持久化保存用户的用户名密码的。

之所以放在数据库,就是因为其是存储在磁盘中,不会因为服务器的宕机而使得数据丢失。而存到磁盘类数据库是最方便的处理方式。

用户在登录的时候,经过和数据库的内容进行对比后,验证成功后。在servlet时代,我们有requset、response、session对象,a4cb05158223a13c144f983ce3d46a1f.png这些对象当然现在还在使用,使用这些对象使得这个登录在一次跳转还是一次登录还是关闭浏览器之前一直处于登录状态。

不管如何,最长的时间就是在你关闭浏览器那刻,也就是说,重新打开浏览器重新打开网站要重新登录。

而如今的网站,你会发现登录都会保持好几天的时间。那么这个是如何做到的呢?

b046977c944f9feabf40c1a20d2afad0.png

那就不得不提出今天的主角JWT(JSON WEB TOKEN)

同servlet验证阶段一样,都需要数据库并进行用户名密码验证。经过验证之后,服务器这里会生成一个TOKEN,然后将其发送给浏览器,浏览器将其保存在cookie内,每次请求携带即可。

而说起TOKEN,它是如何保证用户的身份呢,这里先说说token的结构,它是由三个部分组成,看起来会是xxxx.yyyy.zzzz这个样子f02fd60f65c18d28db8b1d755e15a06d.png

  • 第一部分 Header一般保存token类型和加密算法方式然后进行base64编码得到第一部分(这个只是编码,不是加密,可以反编码回去)
  • 第二部分 Payload一般是用户和其他数据声明然后进行base64编码得到第二部分
  • 第三部分 Signature用第一部分和第二部分编码过后的值加上服务器自己知道的密钥,然后使用第一部分声明的加密算法进行加密后得到第三部分

因为是编码,所以第二部分简单来说只会放用户名而不会放密码等敏感性数据。

为什么能保证用户即为本人?7a550a1fc2e462138cdca4727729b9c2.png

  1. 外部人员获取了这条token后,由第一部分和第二部分进行反编码后得到了原有值,但是原有值是无密码的,因此不能获取到登录全信息。
  2. 外部人员也不能自己伪造token,因第三部分是经过加密的,是无法反解密的。而那个密钥是服务器自己知道的,因此外部人员无法伪装出这条token的第三部分,因此保证安全。

注意:当然如果你的密钥被别人发现,那么说什么也没有用dc7c1f203a3736cd9502d90af4b9a106.png

一般给token设置一个有效期,只要用户用同一个浏览器不清除cookie就可以保证在有效期内一直是登陆状态。

除此之外,jwt技术当前最广泛应用的是单点登录(听起来很高大上是吧ee97438fa517d94f85ec370f417fa7de.png)。

比如说:你有一个百度账号,你在百度知道上面登录了你的账号之后,那么百度地图、百度网盘、百度贴吧等百度旗下产品,你都不需要登录。这就是单点登录。

而在当前微服务横行的时代,只需要剥出一个服务去做Token验证即可使所有服务应用这个服务,非常便利。

公众号回复github、博客等获取相应地址

如有其他情景想了解请留言

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值