单点登录(SSO)原理

  1. 什么是单点登录
    单点登录,即SSO(Single Sign On),是指在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统

  2. 单点登录实现原理

  • 当访问某个系统时,先从session中获取用户信息,如果为null,则跳转到登录服务器(url中带上系统1浏览器的访问路径)进行登录,登录成功后,生成一个token,将token:用户信息放入到redis缓存中,并将token_id:token存入登录服务器的cookie中,然后重定向到系统1浏览器(带上token).
  • 系统1浏览器根据token获取redis缓存中存放的用户信息,将用户信息放入到session中
  • 当访问其他信任系统时,先从session中获取用户信息,如果为null,则跳转到登录服务器(带上自己访问系统的url),如果登录服务器的cookie中有token_id,则说明之前其他的信任系统已经登录过了,则带上cookie中的token值重定向到访问的系统页面,根据token值从redis缓存中获取用户信息,并将用户信息放入到session中.从而达到用户只需要登录一次就可以访问所有相互信任的应用系统的效果.
  1. 实现参考
    代码参考233-235
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值