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----> ...
随机推荐
- FSMC stm32
1.FSMC机制 FSMC(Flexihie Static Memory Controller,可变静态存储控制器)是STM32系列中内部集成256 KB以上FlaSh,后缀为xC.xD和xE的高存储 ...
- IOS网络开发概述
概览 大部分应用程序都或多或少会牵扯到网络开发,例如说新浪微博.微信等,这些应用本身可能采用iOS开发,但是所有的数据支撑都是基于后台网络服务器的.如今,网络编程越来越普遍,孤立的应用通常是没有生命力 ...
- wcf之OperationContextScope
作用:使用消息头向服务发送额外的信息. 1.客户端代码如下: namespace Client { class Program { static void Main(string[] args) { ...
- VirtualizingStackPanel
<FlipView x:Name="flipView1" ItemsSource="{Binding}" ScrollViewer.HorizontalS ...
- AWK处理日志入门(转)
前言 这两天自己挽起袖子处理日志,终于把AWK给入门了.其实AWK的基本使用,学起来也就半天的时间,之前总是靠同事代劳,惰性呀. 此文仅为菜鸟入门,运维们请勿围观. 下面是被处理的日志的示例,不那么标 ...
- 发布b3log-solo后,访问http://localhost:8080/b3log-solo/提示错误为staticServePath Error。
发布b3log-solo后,访问http://localhost:8080/b3log-solo/提示错误为staticServePath Error. latke.props内容为: serverS ...
- ZOJ Problem Set - 3643 Keep Deleting
题目大意: 给出a和b串,a是b串的子串,如果b串有连续的a串,那么就将b串的a串删除,问删除多少次: 题目分析: 打比赛的时候没敲出来,后来想到用栈的思想去模拟就行,网上还有用KMP+栈去做的,没有 ...
- UI学习笔记---第三天
视图控制器 功能:视图大小变换 \布局视图\响应事件\检测处理内存警告\检测以及处理屏幕旋转\检测视图切换 MVC (model View controller) UIViewController是M ...
- Java 性能优化实战记录(3)--JVM OOM的分析和原因追查
前言: C/C++的程序员渴望Java的自由, Java程序员期许C/C++的约束. 其实那里都是围城, 外面的人想进来, 里面的人想出去. 背景: 作为Java程序员, 除了享受垃圾回收机制带来的便 ...
- C# 托管资源和非托管资源
托管资源指的是.NET可以自动进行回收的资源,主要是指托管堆上分配的内存资源.托管资源的回收工作是不需要人工干预的,有.NET运行库在合适调用垃圾回收器进行回收. 非托管资源指的是.NET不知道如何回 ...