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----> ...
随机推荐
- C++的三种继承方式简述
C++对父类(也称基类)的继承有三种方式,分别为:public继承.protected继承.private继承.三种继承方式的不同在于继承之后子类的成员函数的"可继承性质". 在说 ...
- metaprogramming笔记
动态多态与静态多态 动态多态:允许我们通过单个基类指针或引用处理多个派生类型的对象. 模板元编程中强调静态多态,允许不同类型的对象以同样的方式被操纵,只要它们支持某种共通的语法即可. 动态多态,连同& ...
- ubuntu 输入时弹出剪切板候选项
fcitx很坑的把这个功能的快捷键设置成了ctrl + ;结果我在用vim的时候怎么也 没法输入command 不知道是哪次更新引入的,简直是坑人! 我找了半天系统设置都没找到这个快捷键是在哪设置的. ...
- Day1 summary
对比了几篇在hadoop环境中实现关联规则.频繁项集的论文,文章结构都涉及mapreduce模型.传统与改进apriori算法比较.实验结果分析(数据规模-用时or加速比,节点-用时or加速比).有一 ...
- php大力力 [028节] 如何下载js文件,网上一个*.js无法下载啊??????
php大力力 [028节] 如何下载js文件,网上一个*.js无法下载啊?????? safari也无法下载 迅雷也无法下载 是不是对方网站服务器的不让下载那个js目录的文件??? 只能调用js函数啊 ...
- 多态-II(接口实现)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...
- 【LeetCode OJ】Best Time to Buy and Sell Stock II
Problem Link: http://oj.leetcode.com/problems/best-time-to-buy-and-sell-stock-ii/ We solve this prob ...
- 换个心境搞IT,在IT职场如何打拼?
刚进入IT这行时,我也是从程序员做起.尤其是前两三个月里,那种感觉就像时时刻刻处于备战状态一样.我是一个在对自己的要求方面有洁癖的人,在没有任何经验的状态下,只有坚持苦干,把下发的每件编程任务做好,才 ...
- dedecms织梦
dedecms的安装,其修改连接数据库文件是:common.inc.php
- ci总结
1.创建模型,在模型中加载$this->load->database();2.在模型中写入想实现的功能方法3.在控制器中加载辅助函数和模型,$this->load->model ...