当前位置: 首页 > news >正文

【面试集锦】如何设计SSO方案?和OAuth有什么区别?

如何设计SSO方案?和OAuth有什么区别?

--楼兰

带你聊最纯粹的Java

​ 如果面试问你,你会做一个权限系统吗?那你肯定会说做过。不就是各种登录、验证吗。我做的第一个CRUD应用就是注册、登录。简单!但是,如果问你在工作中真的做过权限系统吗?其实很多人都只能默默摇摇头。因为在很多真实项目中,权限系统可能不是最复杂的,但一定是牵连最广的。因此往往大型项目中真正去做权限系统的,都只是非常核心的一小部分人。而如果你的应用越来越复杂,作为安全门户的权限系统也会随着变得更加复杂。各种方案层出不穷。比如, 把SSO和OAuth这两个聊的最多的名词放到一起,你真的分清楚吗?


一、SSO与OAuth


​ 首先你要清楚, SSO和OAuth都是分布式场景下比较常见的权限认证方案。然后,这两个方案,在项目落地时,很多项目都会用SpringSecurity这一类的权限框架实现。所以,这两东西他们其实很像,但本质上,他们完全是两个不同的方案,解决不同的问题。

​ SSO是Single Sign-On,单点登录。主打的是统一。允许用户通过一次登录访问多个相互信任的系统,无需重复输入凭证。比如,你登录了淘宝后,访问天猫,自然也是登录的状态。而如果在淘宝退出登录后,访问天猫也同时退出登录了。

​ OAuth是Open Authorization,开放授权。主打的是开放。允许用户注册的一个账号,可以用来登录多个不同的平台。他们有很多本质的区别。比如,你可以用一个微信账号

http://www.lryc.cn/news/535693.html

相关文章:

  • Python 基于 OpenCV 的人脸识别上课考勤系统(附源码,部署教程)
  • vcredist_x64.exe 是 Microsoft Visual C++ Redistributable 的 64 位版本
  • Tailwind CSS 的核心理念
  • 集成学习(二):从理论到实战(附代码)
  • HTML 链接
  • 【机器学习】数据预处理之scikit-learn的Scaler与自定义Scaler类进行数据归一化
  • android的第一个app项目(java版)
  • 上位机知识篇---SSHSCP密钥与密钥对
  • 智慧物流新引擎:ARM架构工控机在自动化生产线中的应用
  • [MySQL]2-MySQL索引
  • DeepSeek冲击下,奥特曼刚刚给出对AGI的「三个观察」,包括成本速降
  • 新数据结构(8)——包装类
  • P5:使用pytorch实现运动鞋识别
  • 讲解下SpringBoot中MySql和MongoDB的配合使用
  • 《手札·行业篇》开源Odoo MES系统与SKF Observer Phoenix API在化工行业的双向对接方案
  • 数据结构与算法之数组: LeetCode 905. 按奇偶排序数组 (Ts版)
  • 【STM32】HAL库Host MSC读写外部U盘及FatFS文件系统的USB Disk模式
  • docker nginx 配置文件详解
  • 如何实现华为云+deepseek?
  • 【学习笔记】计算机网络(三)
  • 稀土抑烟剂——为汽车火灾安全增添防线
  • Qt Pro、Pri、Prf
  • 基于AIOHTTP、Websocket和Vue3一步步实现web部署平台,无延迟控制台输出,接近原生SSH连接
  • 如何在MacOS上查看edge/chrome的扩展源码
  • 【xdoj-离散线上练习H】T234(C++)
  • Docker Desktop Windows 安装
  • springCloud-2021.0.9 之 GateWay 示例
  • JDK8 stream API用法汇总
  • windows生成SSL的PFX格式证书
  • 玩转大语言模型——使用Kiln AI可视化环境进行大语言模型微调数据合成