OAuth2.0详解
1.使用场景
A系统存放着订单信息
B系统需要查询A系统中的订单信息,但是必须要A系统验证通过后,才能查询。
此时,我们有两种验证方式:
1)拥有A系统的账户/密码
弊端是对A系统来说,直接提供账户/密码的方式非常不安全。
2)A系统给B系统颁发一个令牌,规定了令牌的使用范围和有效期,可以理解为一个通行证。
第二种方式,就是我们所说的OAuth授权。
2.OAuth原理
我们称待授权系统为“客户端”,授权系统为“服务器”
OAuth的原理是,“客户端”不能直接登录“服务器”,“客户端”登录时,“服务端”有一个“授权层”,会首先检验颁发给“客户端”的“令牌”是否有效,若有效,则允许登录。
3.OAuth验证流程

(A)客户端请求用户授权
(B)用户同意授权给客户端
(C)客户端使用上一步获得的授权,像服务器申请令牌
(D)服务器对客户端进行认证后,确认无误,同意发送令牌
(E)客户端使用令牌,向服务器请求资源
(F)服务器确认令牌无误,返回资源
上述步骤中,关键是用户如何给客户端授权。有了授权后,客户端就可以获得令牌,继而获得资源。
4.客户端授权的四种模式
授权码模式
简化模式
密码模式
客户端模式
5.授权码模式

(A)用户访问客户端,客户端将用户导向服务器,包含了“重定向URI”地址
(B)用户选择是否给予客户端授权
(C)若给予,服务器将用户导向“重定向URI”地址,同时附上一个授权码
(D)客户端收到授权码,附上“重定向URI”地址,向服务器申请令牌
(E)服务端核对授权码和重定向URI,确认无误,向客户端发送访问令牌和更新令牌
授权模式的特点是,需要通过客户端服务器,来和服务器端进行交互。
6.简化模式
简化模式不需要客户端服务器,直接通过浏览器向服务器申请令牌,跳过了“授权码”
所有步骤在浏览器中完成,不需要认证客户端。

(A)客户端将用户导向服务器
(B)用户决定是否给予客户端授权
(C)若授权,服务器将用户导向客户端指定的“重定向URI”,URI的hash部分包含了访问令牌。
(D)浏览器向服务器发出请求,不包括上一步收到的hash值
(E)服务器返回一个网页,其中包含的代码可以获取hash值中的令牌
(F)浏览器执行上一步获得的脚本,提取出令牌
(G)浏览器将令牌发给客户端
7.密码模式
用户向客户端提供自己的用户名和密码,客户端使用用户名/密码,向服务器索要授权
客户端不得储存密码,通常是一些大品牌信誉好的公司,才用这种模式。

(A)用户向客户端提供用户名/密码
(B)客户端讲用户名/密码发给服务器,请求令牌
(C)服务器确认无误,向客户端提供访问令牌
8.客户端模式
客户端以自己的名义,而不是用户的名义,向服务器进行认证。用户直接向客户端注册,客户端以自己的名义要求服务器提供服务,其实不存在授权问题。

(A)客户端向服务器进行身份认证,并要求一个访问令牌
(B)服务器确认无误,向客户端提供访问令牌
9.更新令牌
客户端的访问令牌过期后,需要使用更新令牌申请一个新的访问令牌
OAuth2.0详解的更多相关文章
- Oauth2.0详解及安全使用
引言:刚刚参加工作的时候接到的第一个任务就是接入新浪的联合登录功能,当时新浪用的还是oauth1.0协议.接入的时候没有对oauth协议有过多的了解,只是按照开放平台的接入流程进行开发,当时还在想这么 ...
- Oauth2.0详解,Oauth2.0协议原理
角色: RO (resource owner): 资源所有者,对资源具有授权能力的人,通常比喻为用户 RS (resource server): 资源服务器,存储资源.并处理对资源的访问请求 Clie ...
- 百度大脑UNIT3.0详解之嵌入式对话理解技术
相信很多人都体验过手机没有网时的焦虑,没有网什么也做不了.而机器人也会遇到这样的时刻,没有网或者网络环境不好的情况下,无法识别用户在说什么,也无法回复用户.在AIoT(AI+物联网)飞速普及的现在,智 ...
- 百度大脑UNIT3.0详解之知识图谱与对话
如今,越来越多的企业想要在电商客服.法律顾问等领域做一套包含行业知识的智能对话系统,而行业或领域知识的积累.构建.抽取等工作对于企业来说是个不小的难题,百度大脑UNIT3.0推出「我的知识」版块专门为 ...
- 百度大脑UNIT3.0详解之数据生产工具DataKit
在智能对话项目搭建的过程中,高效筛选.处理对话日志并将其转化为新的训练数据,是对话系统效果持续提升的重要环节,也是当前开发者面临的难题之一.为此百度大脑UNIT推出学习反馈闭环机制,提供数据获取.辅助 ...
- Mongostat 3.0详解
可以参考之前写的这篇博客: Mongostat 2.6详解 mapped Changed in version 3.0.0. Only for MMAPv1 Storage Engine. The t ...
- setTimout( , 0) 详解
setTimout( , 0) 一.前言 前端工程师们工作久了,一般都会在某些地方看见过这样的代码: setTimeout(function(){ // TODO }, 0); 举个实例,移动端我们经 ...
- CM自动化安装CDH5.14.0详解
CDH5.14.0版本说明 CDH最早版本只包含hadoop.hive.hbase等基础组件,CDH5.14.0版本目前已经封装了spark.impala.kudu(CDH 5.13.x开始)等众多组 ...
- Android数据存储之GreenDao 3.0 详解
前言: 今天一大早收到GreenDao 3.0 正式发布的消息,自从2014年接触GreenDao至今,项目中一直使用GreenDao框架处理数据库操作,本人使用数据库路线 Sqlite----> ...
随机推荐
- intent 传参数
一.传递List<String>和List<Integer>以下以传递List<String>为例,发送List<String>语法为:intent.p ...
- Mac commands
/System/Library/Frameworks/JavaVM.framework/Versions/Current/Commands/java uname -a 显示系统隐藏文件.在终端(Ter ...
- 大型HashMap
看到一篇评估大型HashMap的文章,备份几个Collections库. 原文:Large HashMap overview: JDK, FastUtil, Goldman Sachs, HPPC, ...
- windows socket网络编程基础知识
下面介绍网络7层协议在WINDOWS的实现: 7层协议 WIN系统 ________________________________________ 7 应用层 7 应用程序 ____________ ...
- linux命令:mv
1.命令介绍: mv是move的缩写,用来移动文件或重命名文件 2.命令格式: mv [选项] 源文件 目标文件 3.命令参数: -b :若需覆盖文件,则覆盖前先行备份. -f --force:fo ...
- linux命令:cd
1.介绍: cd可以说是linux下最基本的命令,全称是change directory. 2.命令格式: cd [DIRECTORY] 3.命令功能: 切换到指定目录 4.常用范例: 例一:切换到根 ...
- 完美解决方案,可排除DATASET不支持System.Nullable错误
完美解决方案,可排除DATASET不支持System.Nullable错误 using System; using System.Collections.Generic; using System.L ...
- 关于IE条件注释(译)
本文翻译自此篇文章.翻译纯属业余. 许多网站为了确保他们的站点能够在不同的浏览器上有不同的显示效果而使用特征检测,一些传统的网站使用其他技术,诸如在服务器或客户端上使用脚本去检测浏览器类型.在这里我们 ...
- JavaScript数据结构——栈和队列
栈:后进先出(LIFO)的有序集合 队列:先进先出(FIFO)的有序集合 --------------------------------------------------------------- ...
- 'dict' object has no attribute 'a'
a = {} #a.a = 'a' #AttributeError: 'dict' object has no attribute 'a' #a['a'] #KeyError: 'a' a['a'] ...