web常见登录实现方式总结

为什么需要登录

HTTP是一种无状态的协议,客户端每次发送请求时会与服务器建立一个连接,请求之后断开连接。因此每次请求都是独立的,服务器无法判断每次请求是否是来自同一个用户。所以登录是为了让服务器在多次请求之间能识别出用户。

实现登录的思路

暂时抛开具体的技术不谈,我们先思考一下登录的实现。

以用户名密码登录为例,用户输入的用户名、密码校验成功后,登录成功。那么如何知道后续的请求都来自这个用户呢?考虑到HTTP的无状态性,后面的每次请求都应该带上一个能唯一识别用户的标识。

如果这个标识是单纯的用户名+密码,我们有两种实现思路:一种是每次都让用户输入用户名密码,这样虽然安全,但显然会造成极差的用户体验,因此舍掉。另一种是将用户名密码存储在某个位置,每次请求时自动带上,这样虽然方便,但直接存储用户名密码显然很容易被盗取,毫无安全性可言。

因此,我们想到用另一个标识代替用户名密码。这个标识最好是谁都看不懂的那种,而且它必须不重复,每个人拥有的标识都是独一无二的。由此一来,又引发出三个问题:

  1. 这个标识从哪来?
  2. 客户端怎么将标识传给服务端?
  3. 服务端该如何验证这个标识?

为了解决这三个问题,引入如下技术,这也是目前业界通用的登录方案:

Cookie + Session

根据该技术的实现方案,依次回答上面三个问题:

  1. 这个标识从哪来?

    用户首次登录成功后,服务端会生成一个sessionId,这个sessionId就是唯一标识。这里的sessionId由我们指定的算法生成。因此这个标识由服务端生成,然后通过设置头Set-Cookie在客户端存储。

  2. 客户端怎么将标识传给服务端?

    客户端从服务端拿到cookie,在之后的每次请求都带上这个cookiecookie中存储的就是这个标识。

  3. 服务端该如何验证这个标识?

    服务端在生成sessionId的同时也存储了sessionId与用户信息的映射关系。因此在验证标识的时候,会从映射关系表中查找这个sessionId,如果找到了就验证成功,并拿到用户信息,否则验证失败。

通过以上回答,你可能又会冒出一个问题:

  • 8
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值