第十一节:IdentityServer4授权码模式介绍和代码实操演练

一. 前言

1.简介

  授权码模式(authorization code)是功能最完整、流程最严密的授权模式。它的特点就是通过客户端的后台服务器,与"服务提供商"的认证服务器进行互动。

2. 流程图

流程

(A)客户端将用户导向认证服务器。

(B)用户决定是否给于客户端授权。

(C)假设用户给予授权,认证服务器将用户导向客户端指定的"重定向URI",并在URI的Hash部分包含了访问令牌。

(D)浏览器向资源服务器发出请求,其中不包括上一步收到的Hash值(#号的部分)。

(E)资源服务器返回一个网页,其中包含的代码可以获取Hash值中的令牌。

(F)浏览器执行上一步获得的脚本,提取出令牌。

(G)浏览器将令牌发给客户端。

(H)客户端拿到令牌以后,就可以去请求资源服务器获取资源了。

3. 流程剖析

步骤A:导向认证服务器,如下请求,进而再导向认证服务器的登录页面。

GET /authorize?response_type=token&client_id=s6BhdRkqt3&state=xyz&redirect_uri=https%3A%2F%2Fclient%2Eexample%2Ecom%2Fcb 

参数包括:

  response_type:表示授权类型,此处的值固定为"token",必选项。

  client_id:表示客户端的ID,必选项。

  redirect_uri:表示重定向的URI,可选项。

  scope:表示权限范围,可选项。

  state:表示客户端的当前状态,可以指定任意值,认证服务器会原封不动地返回这个值。

步骤C:服务器回应客户端的URI

Location  http://example.com/cb#access_token=2YotnFZFEjr1zCsicMWpAA&state=xyz&token_type=example&expires_in=3600

参数包括:

  access_token:表示访问令牌,必选项。

  token_type:表示令牌类型,该值大小写不敏感,必选项。

  expires_in:表示过期时间,单位为秒。如果省略该参数,必须其他方式设置过期时间。

  scope:表示权限范围,如果与客户端申请的范围一致,此项可省略。

  state:如果客户端的请求中包含这个参数,认证服务器的回应也必须一模一样包含这个参数。

步骤D:浏览器会访问Location指定的网址,但是Hash部分(#后的部分)不会发送

步骤E:服务提供商的资源服务器发送过来的代码,会提取出Hash中的令牌。

二. 代码实操

2. 基于IDS4代码实操

3. 测试验证

 

 

 

参考文档:https://www.ruanyifeng.com/blog/2014/05/oauth_2_0.html

!

  • 作       者 : Yaopengfei(姚鹏飞)
  • 博客地址 : http://www.cnblogs.com/yaopengfei/
  • 声     明1 : 如有错误,欢迎讨论,请勿谩骂^_^。
  • 声     明2 : 原创博客请在转载时保留原文链接或在文章开头加上本人博客地址,否则保留追究法律责任的权利。
 

猜你喜欢

转载自www.cnblogs.com/yaopengfei/p/13204109.html