理解OAuth2

一.什么是OAuth2

  1. 用于REST/APIs的代理授权框架(delegated authorization framework)
  2. 基于令牌Token的授权,在无需暴露用户密码的情况下,使应用能获取对用户数据的有限访问权限
  3. 解耦认证和授权
  4. 事实上的标准安全框架,支持多种用例场景
    • 服务器端WebApp
    • 浏览器单页SPA
    • 无线/原生App
    • 服务器对服务器之间

二.场景

  1. 开放系统间授权
    • 社交联合登录
    • 开放API平台
  2. 现代微服务安全
    • 单页浏览器App(HTML5/JS/无状态)
    • 无线原生App
    • 服务器端WebApp
    • 服务器端WebApp
  3. 企业内部应用认证授权(IAM/SSO)

三.不足

  1. 协议框架太宽泛,造成各种实现的兼容性和互操作性差
  2. 和OAuth 1.0不兼容
  3. OAuth 2.0不是一个认证协议,OAuth 2.0本身并不能告诉你任何用户信息

四.主要角色

在这里插入图片描述

  • 客户应用:通常是一个Web或者无线应用,它需要访问用户的受保护资源
  • 资源服务器:是一个web站点或者web service API,用户的受保护数据保存于此
  • 授权服务器:在客户应用成功认证并获得授权之后,向客户应用颁发访问令牌Access Token
  • 资源拥有者:资源的拥有人,想要分享某些资源给第三方应用
  • 客户凭证:客户的clientId 和密码用于认证客户
  • 令牌:授权服务器在接收到客户请求后,颁发的访问令牌
  • 作用域:客户请求访问令牌时,由资源拥有者额外指定的细分权限(permission)

五.OAuth令牌类型

  • 刷新令牌:用于去授权服务器获取一个新的访问令牌
  • Bearer Token:不管谁拿到Token都可以访问资源,像现钞
  • 访问令牌(Access Token):用于代表一个用户或服务直接去访问受保护的资源
  • Proof of Possession(PoP) Token:可以校验client是否对Token有明确的拥有权

六.模式

1.类型

1.1授权码模式

在这里插入图片描述

1.2.简化模式

在这里插入图片描述

1.3.密码模式

在这里插入图片描述

1.4.客户端模式

在这里插入图片描述

1.5.刷新令牌

在这里插入图片描述

2.特点

在这里插入图片描述

选择

在这里插入图片描述

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值