工程开发之OAuth2

一、OAuth2是什么?

OAuth2是目前最流行的授权协议, 用来授权第三方应用,获取用户数据。此授权协议一般涉及的角色有:Resource Owner(资源持有者)、Client(客户端)、Authorization Server(授权服务器)、Resource Server(资源服务器)、User Agent(中介,如浏览器)。

先看两个栗子:

第一个是快递员授权机制设计;第二个是用户使用QQ账号登录京东的过程

以上两个均为授权验证的场景,现在尝试从两个场景中抽象出性质相同(或者相近)的角色;

客户端(需要得到授权的角色):案例1是快递员;案例2是京东网站

资源服务器和授权服务器:案例1是门禁系统(以及小区的门?);案例2是QQ

再次以案例2来说明,因为客户端和认证服务器双方的不信任产生的这样一个授权协议,如果信任QQ开放数据库给京东,就可省去跳来跳去的环节。

OAuth2.0和1.0的区别

1)2.0授权模式有4种,而1.0授权模式只有1种;

2)1.0版本用的是http协议,申请RequestToken过程中,容易被攻击者调包,调拨后目的是伪造回调地址,拿到用户的accessToken。2.0版本针对上述问题做了四点改进:①去掉了签名,改用SSL(HTTPS)确保安全性;②所有的token不再有对应的secret存在,签名过程简洁,这也直接导致OAuth2.0不兼容老版本;③能更好地支持不是基于浏览器的应用;④OAuth2.0的访问令牌是“短命的”,且有刷新令牌。

二、OAuth2授权模式解析

1)授权码模式

2)简化模式

简化模式不通过第三方应用程序的服务器,直接在浏览器中向认证服务器申请令牌,跳过“授权码”这个步骤,因此称简化模式(简化是相对授权码模式而言)。

3)密码模式

密码模式中,用户向客户端提供自己的用户名和密码,这通常用在用户对客户端高度信任的情况,项目采用此种模式。

4)客户端模式

客户端模式是指客户端用自己的名义而不是用户的名义向服务提供者申请授权,很少使用。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
,包含授权服务和开放平台 Docker 镜像,基于 Spring Boot Starter 的资源服务工具包和客户端(第三方应用)工具包 开发工具在软件开发生命周期中扮演着至关重要的角色,它们旨在简化和加速从概念设计到产品部署的各个环节。以下是开发工具的主要作用: 代码编写与编辑: 提供集成开发环境(IDE),如Visual Studio、Eclipse、Android Studio和Sublime Text等,这些工具集成了文本编辑器,支持语法高亮、自动补全、代码片段管理和版本控制等功能,有助于开发者高效编写和维护代码。 项目管理: 支持项目创建、组织、构建自动化以及依赖管理,确保不同模块和组件之间的协调一致。 编译与构建: 包括编译器、构建工具(如Make、Gradle、Maven)等,用于将源代码转换为可执行文件或库,并进行资源打包、优化等处理。 调试与测试: 集成调试器允许开发者逐行执行代码,设置断点、查看变量值、跟踪调用堆栈等,帮助定位并修复代码中的错误。 测试框架和工具则协助开发者编写和运行单元测试、集成测试及性能测试,确保软件质量。 版本控制与协作: 通过集成Git、SVN等版本控制系统,支持团队成员间的代码共享、分支管理、合并请求和冲突解决。 可视化设计与原型制作: 对于UI/UX设计,有界面设计工具,如Sketch、Adobe XD,可以帮助设计师快速构建应用程序界面模型,并生成规范的设计稿供开发人员参考实现。 跨平台支持: 跨平台开发工具如Xamarin、React Native和Flutter,让开发者使用一种语言或框架编写可以在多个操作系统上运行的应用程序。 文档编写与API管理: 文档生成工具可以自动生成代码注释文档,便于团队内外理解和使用项目代码。 API管理工具则方便开发者创建、测试、发布和维护API接口。 持续集成与持续部署(CI/CD): Jenkins、Travis CI、GitHub Actions等工具负责自动化构建、测试和部署流程,提高交付效率和可靠性。 数据库管理与ORM工具: 数据库客户端工具用于连接、查询、更新数据库,ORM(对象关系映射)工具简化了数据操作和持久化层的开发工作。 总之,开发工具极大地提升了软件工程师的工作效率,保证了开发过程中的准确性与一致性,同时也促进了团队合作,使得软件开发更系统化、规范化和工业化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值