单点登录的设计,从单域名到多域名(经验分享)

个人实践总结,最初的的需求,多个产品线都在同一个根域名下面。

独立的用户中心分离,单独负责用户登录和用户信息获取、变更等处理逻辑。

第一步,用户登录成功,分配给用户一个memToken(令牌),通过cookie来多个产品线共享,后台逻辑,生成memToken和用户id的一个关联关系存入缓存。

memToken生成逻辑,ip+memCard+时间戳+secret ,通过md5生成,可以使用其它方式生成。

第二部,有用户相关操作通过memToken完成,这里有一个地方需要注意,需要有公共的处理层解析处理验证memToken,这样可以自由扩展memToken的验证规则,比如限制某个ip的访问频率、或者拉黑某个ip等一些防爬取的逻辑。

上面就是一个最简易的单点登录实现,但这时候有一个问题出现了...如果我们的多个产品不是同一个根域名怎么办?

这时候其实没有那么复杂,只要做一些改变就好了

第一步:首先,cookie的存储还是可以是某个根域名也可以是用户中心的子域名,但用户中心需要配置好允许浏览器跨域名访问(这个很关键)。

第二部:第一种方式可以通过cookie直接获取到memToken然后再根据memToken获取用户登录状态和登录信息,这里就要变化了,通过在浏览器访问统一的用户中心接口,然后接口不是通过参数获取memToken了,而是改为从cookie获取(这点变化挺明显的)也可以使用其它方法,总之就是曲线实现cookie的共享。注意:通过ajax跨域访问一定要记得开启cookie的信息携带(withCredentials: true)..不然会很坑

删除:基于我们的前面设计memToken和用户关联的逻辑,通过接口实现对memToken关联关系的删除来实现,cookie同步删除。

个人的实践,可能有漏洞也可能有更好的办法,欢迎讨论

qq技术交流群:208779755

 

转载于:https://my.oschina.net/haitaohu/blog/1861103

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当用户第一次访问web应用系统1的时候,因为还没有登录,会被引导到认证中心进行登录;根据用户提供的登录信息,认证系统进行身份效验,如果通过效验,返回给用户一个认证的凭据;用户再访问别的web应用的时候就会将这个Token带上,作为自己认证的凭据,应用系统接受到请求之后会把Token送到认证中心进行效验,检查Token的合法性。如果通过效验,用户就可以在不用再次登录的情况下访问应用系统2和应用系统3了。所有应用系统共享一个身份认证系统。认证系统的主要功能是将用户的登录信息和用户信息库相比较,对用户进行登录认证;认证成功后,认证系统应该生成统一的认证标志,返还给用户。另外,认证系统还应该对Token进行效验,判断其有效性。 所有应用系统能够识别和提取Token信息要实现SSO的功能,让用户只登录一次,就必须让应用系统能够识别已经登录过的用户。应用系统应该能对Token进行识别和提取,通过与认证系统的通讯,能自动判断当前用户是否登录过,从而完成单点登录的功能。 比如说,我现在有3个分站点和1个认证中心(总站)。当用户访问分站点的时候,分站点会发Token到验证中心进行验证。验证中心判断用户是否已经登录。如果未登录,则返回到验证中心登录入口进行登录,否之则返回Token验证到分站点,直接进入分站点
当用户第一次访问web应用系统1的时候,因为还没有登录,会被引导到认证中心进行登录;根据用户提供的登录信息,认证系统进行身份效验,如果通过效验,返回给用户一个认证的凭据;用户再访问别的web应用的时候就会将这个Token带上,作为自己认证的凭据,应用系统接受到请求之后会把Token送到认证中心进行效验,检查Token的合法性。如果通过效验,用户就可以在不用再次登录的情况下访问应用系统2和应用系统3了。所有应用系统共享一个身份认证系统。认证系统的主要功能是将用户的登录信息和用户信息库相比较,对用户进行登录认证;认证成功后,认证系统应该生成统一的认证标志,返还给用户。另外,认证系统还应该对Token进行效验,判断其有效性。 所有应用系统能够识别和提取Token信息要实现SSO的功能,让用户只登录一次,就必须让应用系统能够识别已经登录过的用户。应用系统应该能对Token进行识别和提取,通过与认证系统的通讯,能自动判断当前用户是否登录过,从而完成单点登录的功能。 比如说,我现在有3个分站点和1个认证中心(总站)。当用户访问分站点的时候,分站点会发Token到验证中心进行验证。验证中心判断用户是否已经登录。如果未登录,则返回到验证中心登录入口进行登录,否之则返回Token验证到分站点,直接进入分站点
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值