Oauth2.0详解,Oauth2.0协议原理
角色:
- RO (resource owner): 资源所有者,对资源具有授权能力的人,通常比喻为用户
- RS (resource server): 资源服务器,存储资源、并处理对资源的访问请求
- Client:第三方应用,它通过RO确认后,获得RO的授权后便可以去访问RS上的RO对应资源
- AS (authorization server): 授权服务器,它认证RO的身份,为RO提供授权审批流程并最终颁发授权令牌(Access Token)。
PS:通常和RS放到一起
授权模式:
前言:在一般的授权流程中,Client第三方应用可能是一个web程序,也有可能是一段命令行代码。或者其他一些脚本,为了保护其安全性。关于用户的一些秘钥,可以选择不给用户(RO)暴露。但对于第三方应用,还是可以访问到用户的数据。
支持这些不同类型的Client,区分除了多种授权模式。
- 授权码 (Authorization Code Grant)
- 隐式授权 (Implicit Grant)
- RO凭证授权 (Resource Owner Password Credentials Grant)
- Client凭证授权 (Client Credentials Grant)
授权码模式 (Authorization Code Grant):
典型的web流程:
- 第三方应用程序(Client),将用户(RO)当前页面重定向到授权服务器(AS),在用户确认授权或取消授权后,重定向回一个由第三方web应用程序制定的url。
- 授权服务器(AS)验证用户(通过http头),并确定用户是否允许第三方应用程序访问用户资源(RS)
- 如果用户确认授权第三方应用程序,授权服务器(AS),将会重定向到由第一步第三方应用程序设定的一个url,并返回一个授权码(就是个临时认证字符串)。
- 第三方应用程序通过验证并传入由上一步获取的授权码参数再去授权服务器上验证并获取一个令牌。
隐式授权模式 (Implicit Grant):
- 用户访问第三方应用程序时(client),第三方应用将用户重定向到授权服务器(AS)。
- 授权服务器(AS)生成一个页面,来提供给用户是否授权
- 如果用户授权,授权服务器(AS)向第三方应用页面返回令牌
- 第三方应用获取到上一步返回的令牌,去资源服务器获取用户的资源(前提是令牌没问题)
密码模式 (Resource Owner Password Credentials Grant):
简单来说就是把密码托管给第三方应用,所以在这里。我们要确保第三方应用的高度可信任
- 用户(RO)向第三方应用程序(client)提供账号密码。
- 第三方应用程序获取到上一步的账号和密码,向授权服务器发送请求
- 授权服务器认证账号密码正确后,再向第三方应用程序提供一个令牌
Client凭证授权 (Client Credentials Grant):
这种是最不安全的一种模式,过程并不需要用户去参与,完全就是第三方应用程序与授权服务器的交流
- 用户(RO)访问第三方应用程序
- 第三方应用程序通过自定义的验证方式,拿到令牌。无需通过用户去认证
- 访问资源服务器(RS)
Oauth2.0详解,Oauth2.0协议原理的更多相关文章
- 百度大脑UNIT3.0详解之知识图谱与对话
如今,越来越多的企业想要在电商客服.法律顾问等领域做一套包含行业知识的智能对话系统,而行业或领域知识的积累.构建.抽取等工作对于企业来说是个不小的难题,百度大脑UNIT3.0推出「我的知识」版块专门为 ...
- 百度大脑UNIT3.0详解之数据生产工具DataKit
在智能对话项目搭建的过程中,高效筛选.处理对话日志并将其转化为新的训练数据,是对话系统效果持续提升的重要环节,也是当前开发者面临的难题之一.为此百度大脑UNIT推出学习反馈闭环机制,提供数据获取.辅助 ...
- 13.详解oauth2授权码流程
13.详解oauth2授权码流程 把登陆系统单独独立出来,可以给自己写的微服务用,也可以给第三方的系统调用我们的服务 显式的和隐式的,两种方式,
- (转载)详解7.0带来的新工具类:DiffUtil
[Android]详解7.0带来的新工具类:DiffUtil 标签: diffutil 2017-04-17 18:21 226人阅读 评论(0) 收藏 举报 分类: Android学习笔记(94) ...
- 百度大脑UNIT3.0详解之嵌入式对话理解技术
相信很多人都体验过手机没有网时的焦虑,没有网什么也做不了.而机器人也会遇到这样的时刻,没有网或者网络环境不好的情况下,无法识别用户在说什么,也无法回复用户.在AIoT(AI+物联网)飞速普及的现在,智 ...
- [转帖]万字详解Oracle架构、原理、进程,学会世间再无复杂架构
万字详解Oracle架构.原理.进程,学会世间再无复杂架构 http://www.itpub.net/2019/04/24/1694/ 里面的图特别好 数据和云 2019-04-24 09:11:59 ...
- [转帖]详解Linux系统inode原理--硬链接、软链接、innodb大小和划分等
详解Linux系统inode原理--硬链接.软链接.innodb大小和划分等 原创 波波说运维 2019-07-17 00:03:00 https://www.toutiao.com/i6713116 ...
- RocketMQ详解(一)原理概览
专题目录 RocketMQ详解(一)原理概览 RocketMQ详解(二)安装使用详解 RocketMQ详解(三)启动运行原理 RocketMQ详解(四)核心设计原理 RocketMQ详解(五)总结提高 ...
- 淘宝JAVA中间件Diamond详解(2)-原理介绍
淘宝JAVA中间件Diamond详解(二)---原理介绍 大家好,通过第一篇的快速使用,大家已经对diamond有了一个基本的了解.本次为大家带来的是diamond核心原理的介绍,主要包括server ...
随机推荐
- java之线程中断——interrupt
如下图所示,interrupt()方法并没有成功的中断我们的线程. 为了便于理解,其实可以这样来类比(注意,只是类比,实际情况并不完全是这样):Thread类中有一个boolean的标志域用来表示线程 ...
- JVM系列八(虚拟机性能监控命令).
jps JVM Process Status Tool,显示指定系统内所有的 HotSpot 虚拟机进程.显示信息包括虚拟机执行主类名称以及这些进程的本地虚拟机唯一ID(Local Virtual M ...
- Posix线程编程指南(4)
Posix线程编程指南(4) 杨沙洲 原文地址:http://www.ibm.com/developerworks/cn/linux/thread/posix_threadapi/part4/ 线程终 ...
- OPENGL图形渲染管线图解
OPENGL固定图形渲染管线可以粗略地认为由下面的阶段衔接而成: 顶点颜色,光照,材质三个输入在光栅化前控制绘制管线的操作.光照和材质不能单独使用.顶点颜色,光源颜色,材质颜色都有alpha值,它们的 ...
- webpack资料,还需整理
参考地址: https://github.com/ruanyf/webpack-demos#demo01-entry-file-source http://www.jianshu.com/p/4df9 ...
- JavaScript进阶之高阶函数篇
JavaScript进阶之高阶函数篇 简介:欢迎大家来到woo爷说前端:今天给你们带来的是JavaScript进阶的知识,接下来的系列都是围绕着JavaScript进阶进行阐述:首先我们第一篇讲的是高 ...
- Java 垃圾收集技术
前言 在计算机科学中,垃圾收回(GC: garbage collection)是内存自动管理的一种方式,它并不是同 Java 语言一起诞生的,实际上,早在 1959 年为了简化 Lisp 语言的手动内 ...
- vmware导入ova文件踩坑记
问题来源 众所周知,所有的网络行为都会产生相应的网络流量,那么所有的网络攻击行为也有其对应的流量特点,那么是否能根据流量特点进而分析出其对应的是什么攻击行为呢? 我在虚拟机上使用vulnhub的靶场环 ...
- 大数据软件安装之Flume(日志采集)
一.安装地址 1) Flume官网地址 http://flume.apache.org/ 2)文档查看地址 http://flume.apache.org/FlumeUserGuide.html 3) ...
- gdb中的gef插件
地址 https://github.com/hugsy/gef # via the install script #下载 `gef.sh` 并执行 wget -q -O- https://github ...