单点登录逻辑简单梳理

目的:为解决现在各种服务越来越多,若不使用单点登录,则需要用户登录每个服务,即多次登录,体验很差。单点登录是用户只需要登录一次,就相当于登录了所有服务。

之前以为cas + uim、cas + shiro、 jwt等都是实现单点登录的常见组合。后来发现,cas是中央认证服务,负责用户管理,为单点登录服务。
而uim和shiro是用户权限控制的服务。因此若不需要权限控制,只要单点登录,则只需要cas。
jwt是oAuth2规范的简单实现,是一种token的生成方式。

大概流程:
用户 —> 前端输入账号密码,登陆 —> 前端发给后端 —> 后端去处理登录信息(保存登录信息、生成token之类的),从cas中取出需要的信息 —> 后端去各服务中获取用户需要的信息 —> 返回给前端 —> 前端呈现展示给用户

就是用户的一次登录,后端整合了所有服务的信息然后返回给前端,展现给用户。
对于用户来说只登录了一次,后端相当于做了之前客户登录各服务的操作。

微信等第三方授权登录问题:
微信这种第三方授权登录的,原理据我毫不负责任的猜都是一样的。因为只查了微信授权登录的资料,所以这里只说微信。
用户点击使用微信登录,会弹出授权登录页面,点击同意这类按钮之后,前端会得到一个code,然后发给后端这个code。后端通过这个code加上之前在微信注册的账号(你只有在微信登记了,才可以使用微信授权登录),获取一个token,然后拿着这个token再去向微信请求用户的相关信息。所以其实用户只是省去了自己注册再登录的过程,而是通过后端自己去微信获取用户的信息。后端获取到用户信息这个过程,从原本是通过用户注册变成了后端从微信直接获取用户信息。

所以这种授权登录也是单点登录

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值