OAuth2介绍
什么是OAuth2
百科:OAUTH协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是OAUTH的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此OAUTH是安全的。oAuth是Open Authorization的简写。
简单来说:OAuth2协议,定义了一套用户、第三方服务和存储着用户数据的平台之间的交互规则,可以使得用户无需将自己的用户名和密码暴露给第三方,即可使第三方应用获取用户在该平台上的数据,最常见的场景便是现在互联网上的各种使用XXX账号登录。
OAuth2协议中角介绍
OAuth2协议中,共有四个参与方(角): 
1.resource owner:资源拥有者 
即用户 
2.resource server:资源服务器 
即存储用户数据的服务器,一般对外都以RESTFul API的形式暴露用户数据,client使用access token访问resource server申请被保护起来的用户数据 
3.client:客户端 
即第三方应用 
4.authorization server:授权服务器 
用来鉴权第三方应用合法性,并对用户登录、是否授权第三方应用获取数据进行响应,并根据用户操作,想第三应用颁发用户token或者告知授权失败
OAuth2常用协议介绍
OAUTH2标准业务协议,如下图所示 
 
A.第三方应用向用户请求授权,希望获取用户数据 
B.用户同意授权 
C.第三方应用拿着用户授权,向平台索要用户access token 
D.平台校验第三应用合法性及用户授权真实性后,向平台发放用户access token 
E.第三方应用拿着用户access token向平台索要用户数据 
F.平台在校验用户access token真实性后,返回用户数据
OAuth2使用场景介绍
目前,OAuth2协议使用最多的场景还是用以给第三方应用获取用户信息,业务流程如下图所示 
1.在浏览器中,用户点击第三方应用按钮,由第三方应用发起请求,向平台发起授权请求。 
2.平台在接收到第三方应用请求后,浏览器跳转用户登录界面,请求用户进行登录。 
3.用户在平台登录界面输入用户名、密码进行登录 
4.平台判断用户合法性,校验失败,在浏览器中提示错误原因 
5.平台判断用户是否需要对该第三方应用进行授权。(不需要授权的情况有两种:a.平台信任该第三方应用,如公司内部应用,无需用户进行授权,默认给予用户数据。b.该用户之前已经给该应用授予过权限,并且仍在有效期内) 
6.如需授权,平台跳转浏览器界面至授权界面,告知用户将授予哪个第三方哪些数据权限 
7.用户授权后,将用户授权码回调给第三方url 
8.第三方在获取用户授权码后,带着用户授权码访问平台鉴权接口,请求用户token 
9.平台在收到第三方请求后,校验授权码真实性,并返回用户token 
10.第三方使用用户token向平台请求用户接口 
11.平台接口判断用户token真实性,并向第三方返回用户数据
OAuth2核心功能说明
1.应用注册 
应用注册后,OAuth2会下发应用app_id和app_secret,用以标记该应用的唯一性,并且这两个参数将贯穿整个OAuth协议,用以对应用合法性进行校验。同时,应用需要提供redirect_uri,用以和平台进行异步交互,获取用户令牌及错误信息。 
2.授权/鉴权中心 
a.对用户的应户名、密码进行鉴权 
b.对第三方应用的app_id,app_secret进行鉴权 
c.展示授权界面,并对用户对第三方应用的授权操作进行响应 
d.对用户授权码及用户token的真实性进行鉴权 
3.token管理 
a.创建token、刷新token 
b.查询token详细数据 
c.校验token时效性
OAuth2体系结构
开放平台集成OAuth2体系
1.平台门户: 
门户应用入住界面,需要集成OAuth2应用创建接口,录入第三方回调地址,并回显app_id和app_secret参数 
2.鉴权服务: 
鉴权服务需集成OAuth2的authorize及token接口,用以提供用户授权及code/token鉴权功能 
3.开放接口: 
开放接口需集成OAuth2的resource server角,对用户数据进行安全管理,对第三方应用发起的请求做出响应,并对token进行真实性校验 
4.运营系统: 
运营系统需提供对当前OAuth2应用的管理功能,用户授权列表管理,用户token管理等OAuth2协议相关管理功能。
SSO介绍
什么是SSO
百科:SSO英文全称Single Sign On,单点登录。SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。它包括可以将这次主要的登录映射到其他应用中用于同一个用户的登录的机制。它是目前比较流行的企业业务整合的解决方案之一。
简单来说,SSO出现的目的在于解决同一产品体系中,多应用共享用户session的需求。SSO通过将用户登录信息映射到浏览器cookie中,解决其它应用免登获取用户session的问题。
为什么需要SSO
开放平台业务本身不需要SSO,但是如果平台的普通用户也可以在申请后成为一个应用开发者,那么就需要将平台加入到公司的整体账号体系中去,另外,对于企业级场景来说,一般都会有SSO系统,充当统一的账号校验入口。
CAS协议中概念介绍
SSO单点登录只是一个方案,而目前市面上最流行的单端登录系统是由耶鲁大学开发的CAS系统,而由其实现的CAS协议,也成为目前SSO协议中的既定协议,下文中的单点登录协议及结构,均为CAS中的体现结构 
CAS协议中有以下几个概念: 
1.CAS Client:需要集成单点登录的应用,称为单点登录客户端 
2.CAS Server:单点登录服务器,用户登录鉴权、凭证下发及校验等操作 
3.TGT:ticker granting ticket,用户凭证票据,用以标记用户凭证,用户在单点登录系统中登录一次后,再其有效期内,TGT即代表用户凭证,用户在其它client中无需再进行二次登录操作,即可共享单点登录系统中的已登录用户信息 
app登录界面4.ST:service ticket,服务票据,服务可以理解为客户端应用的一个业务模块,体现为客户端回调url,CAS用以进行服务权限校验,即CAS可以对接入的客户端进行管控 
5.TGC:ticket granting cookie,存储用户票据的cookie,即用户登录凭证最终映射的cookies
CAS核心协议介绍
 
1.用户在浏览器中访问应用 
2.应用发现需要索要用户信息,跳转至SSO服务器 
3.SSO服务器向用户展示登录界面,用户进行登录操作,SSO服务器进行用户校验后,映射
出TGC 
4.SSO服务器向回调应用服务url,返回ST 
5.应用去SSO服务器校验ST权限及合法性 
6.SSO服务器校验成功后,返回用户信息
CAS基本流程介绍
以下为基本的CAS协议流程,图一为初次登录时的流程,图二为已进行过一次登录后的流程 
基于OAUTH单点登录
同域下登录方式
不同域下登录方式

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。