zoukankan      html  css  js  c++  java
  • OAuth2 图解

    本文简单的描述出了 OAuth2 工作背景,看完后可以轻松理解 OAuth2 是用来解决什么问题的。

    1. 用户有自己的数据

    2. 有一个服务器,负责管理用户的数据。这个服务器被称为”Resource Server(资源服务器)“

    3. 有一个客户端应用,想要使用用户的数据

    4. 资源服务器需要准备一个 API 接口,用来传递用户的数据

    5. 客户端应用请求 API 接口,想要用户的数据

    6. 资源服务器返回用户数据

    7. 如果某个客户端应用心术不正怎么办?

    8. 坏客户端应用也请求资源服务器 API

    9. 资源服务器也可以正常返回用户数据

    10. 结果就是坏客户端拿到了用户数据

    11. 我们需要一个机制来保护用户的数据

    12. 根据最佳实践,让客户端应用使用 "Access Token(访问令牌)" 比较好。客户端有了 Token 就说明它有了访问用户数据的权限

    13. 客户端应用请求 API 时出示自己的 Token 令牌

    14. 资源服务器从请求中提取 Token

    15. 资源服务器验证 Token 令牌

    16. 确认之后,资源服务器返回用户数据

    17. 这个机制的前提是客户端得提前拿到 Token 令牌

    18. 我们需要有人负责颁发 Token 令牌

    19. 谁来颁发 Token 令牌 ...

    20. 颁发 Token 的角色被称为 ”Authorization Server(授权服务器)“

    21. 客户端应用需要与授权服务器打交道了

    22. 授权服务器生成 Token 令牌

    23. 然后把 Token 颁发给客户端

    24. 先暂停,回顾一下,现在有3个角色了 ”授权服务器“、”客户端应用“、”资源服务器“

    25. 授权服务器生成 Token

    26. 然后颁发给客户端

    img

    27. 客户端使用 Token 请求资源服务器的 API 接口

    28. 资源服务器从请求中提取 Token

    29. 验证 Token

    30. Token 没问题就返回用户数据

    31. 上面的流程中,第一步是授权服务器生成 Token,而实际流程中,生成 Token 之前是需要询问 User 用户的

    32. 首先,客户端请求授权服务器,申请一个 Token

    33. 授权服务器询问用户,是否给这个客户端权限

    34. 如果用户同意 ...

    img

    35. 那么授权服务器就生成一个 Token

    36. 然后颁发给客户端

    37. 重点就是这个黄色区域

    38. 这块儿是请求 Token、拿到 Token 的过程

    39. 这个过程就是 OAuth2 框架所关注的,为其做了标准化定义

    小结

    以上就是 OAuth2 的工作背景,OAuth2 框架关注的是整个安全认证过程中的 "请求 Token、颁发 Token" 这部分流程。

    这块儿有多种方式,OAuth2 定义了4种模式来处理。

    这4种模式有点复杂,之后再详述。

    翻译整理自

    https://medium.com/@darutk/the-simplest-guide-to-oauth-2-0-8c71bd9a15bb

    推荐阅读

    轻松理解 Kubernetes 的核心概念

    开发者必须要了解的架构技术趋势:Service Mesh

    Elasticsearch 开箱指南

    阿里开源的分布式事务框架 Seata

    ZooKeeper 并不适合做注册中心

  • 相关阅读:
    今天同事给介绍了一个LINQ的工具,LINQPad
    wordpress为不同的category添加不同的模板
    robotframework之使用cookies登陆
    robotframework的变量的使用
    robotframework之用户关键字的用法
    robot framework UI自动化之登录
    用U盘完成win10系统的安装
    robot framework 接口自动化之登录
    postman通过引入外部文件实现参数化
    postman连接mysql执行操作
  • 原文地址:https://www.cnblogs.com/yogoup/p/13092124.html
Copyright © 2011-2022 走看看