首页 > 其他 > 详细

OAuth2 图解

时间:2020-06-11 15:10:36      阅读:82      评论:0      收藏:0      [点我收藏+]

本文简单的描述出了 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. 然后颁发给客户端

技术分享图片

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

技术分享图片

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

技术分享图片

29. 验证 Token

技术分享图片

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

技术分享图片

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

技术分享图片

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

技术分享图片

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

技术分享图片

34. 如果用户同意 ...

技术分享图片

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 并不适合做注册中心

技术分享图片

OAuth2 图解

原文:https://www.cnblogs.com/yogoup/p/13092124.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!