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

如何设计微服务统一认证中心

认证中心简介

单体应用体系下,应用是一个整体,一般针对所有的请求都会进行权限校验。请求一般会通过一个权限的拦截器进行权限的校验,在登录时将用户信息缓存到Session 中,后续访问则从缓存中获取用户信息。

而微服务架构下,一个应用会被拆分成若干个微应用,每个微应用都需要对访问进行鉴权,每个微应用都需要明确当前访问用户以及其权限。尤其当访问来源不只是浏览器,还包括其他服务的调用时,单体应用架构下的鉴权方式就不是特别合适了。

。 认证中心方案所有请求都通过网关,从而有效隐藏微服务;基于Token,服务端无状态,性能较好,支持移动设备,支持跨程序调用;基于OAuth2.0,简单,安全,开放。

认证中心原理

OAuth2

OAuth是一种开放的协议,为桌面程序或者基于 BS的web应用提供了一种简单的,标准的方式去访问需要用户授权的 API 服务。

  1. 简单:不管是 OAuth 服务提供者还是应用开发者,都很容易于理解与使用;
  2. 安全:没有涉及到用户密钥等信息,更安全更灵活;
  3. 开放:任何服务提供商都可以实现 OAuth,任何软件开发商都可以使用 OAuth

OAuth2认证协议流程

为什么使用JWT?

随着技术的发展,分布式应用的普及,通过session管理用户登录状态成本越来越高,因此慢慢发展成为token的方式做登录身份校验,然后通过token去取redis中的缓存的用户信息。随着之后jwt的出现,校验方式更加简单便捷化,无需通过redis缓存,而是直接根据token取出保存的用户信息,以及对token可用性校验,单点登录更为简单。

Json Web Token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。

JWT由三段信息构成:第一段为头部(Header),第二段为载荷(Payload),第三段为签名(Signature)。每一段内容都是一个 JSON 对象,将每一段 JSON 对象采用 BASE64 编码,将编码后的内容用. 点链接一起就构成了 JWT 字符串。

头部(Header):头部用于描述关于该 JWT 的最基本的信息,例如其类型以及签名所用的算法等。这也可以被表示成一个 JSON 对象。{"typ": "JWT","alg": "HS256"}

载荷(Payload):载荷就是存放有效信息的地方。有效信息包含标准的声明、公共的声明、私有的声明。

签名( Signature ):使用 Base64 编码后的 Header 和 Payload 以及一个秘钥。将 base64 加密后的 Header 和 Base64 加密后的 Payload 使用. 连接组成的字符串,通过 Header 中声明的加密方式进行加盐 secret 组合加密。

Spring Security

Spring Security是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架。

一般来说,Web 应用的安全性包括用户认证(Authentication)和用户授权(Authorization)两个部分。

用户认证指的是验证某个用户是否为系统中的合法主体,也就是说用户能否访问该系统。 用户授权指的是验证某个用户是否有权限执行某个操作

认证中心设计


推荐阅读

  1. 如何设计微服务统一认证中心
  2. 云计算中实施身份和访问管理(IAM)架构的最佳实践
  3. 粒度数据权限控制框架
http://www.jsqmd.com/news/505189/

相关文章:

  • 碳化硅器件采购避坑指南:如何识别优质SiC MOSFET供应商(附主流厂商对比表)
  • Petalinux实战:从QSPI Flash启动Linux系统的完整配置指南
  • weixin239基于微信小程序高校订餐系统的设计与开发ssm(文档+源码)_kaic
  • 手把手教你用算能云空间搭建RISC-V版PyTorch环境(含最新CPUINFO补丁)
  • Python DXF处理库架构深度解析:企业级CAD数据处理最佳实践
  • 从电影片段到动作识别:如何用TensorFlow/Keras搭建你的第一个3D CNN视频分类模型
  • YOLOv8实战:5分钟搞定Docker部署(含CUDA加速配置)
  • 别再只用rc.local了!Debian 11/12系统服务开机自启的三种正确姿势(附systemd实战)
  • 基于STM32的智能空气净化器设计与实现(完整项目)
  • Few-shot学习实战:5个技巧让BERT在少量数据上快速微调
  • 探索未来编程的新纪元:Kind——纯函数式编程语言与证明助手
  • C盘空间持续告急?试试Windows Cleaner的智能清理方案
  • 【猫抓cat-catch】:媒体资源智能捕获的全方位技术解析与实战指南
  • 深入Android音频驱动层:AAudio的MMAP_NOIRQ模式是如何实现超低延迟的?
  • MSG文件查看工具:跨平台邮件解析与处理的技术实现与应用指南
  • 从信号到数据:基于NI-DAQ与LabVIEW的光电倍增管(PMT)高速采集系统搭建实战
  • 轻量化特征重构 | 一种基于强弱特征分离与转换的轻量级网络设计 | 技术解析
  • Spring Boot 面试核心笔记
  • spaCy社区与生态:探索丰富的扩展插件和工具集合
  • 掌握大数据领域Kafka的消息分区策略
  • 零基础5分钟上手「时空波动仪」:IBM Granite FlowState时间序列预测实战教程
  • 告别连接难题:Windows 11环境下Multisim主数据库稳定运行全攻略
  • Obsidian PDF++插件:如何打造你的专属护眼PDF阅读环境
  • 手把手教你用Arduino驱动串口屏:从接线到显示‘Hello World’的完整教程
  • 为什么92%的Dify部署在生产环境未启用Judge沙箱?——深度解析动态评分链路中的6类未授权推理逃逸风险
  • Windows Server 2022上Docker部署Dify避坑指南:从Hyper-V配置到镜像加速全流程
  • 别再乱接线了!手把手教你搞定HDMI/DP/Type-C接口的硬件检测电路(附原理图分析)
  • 视频内容结构化提取:自动化PPT提取工具的专业解决方案
  • 【嵌入式C代码质量生死线】:20年老兵亲测的5大静态分析工具选型铁律,错过再等三年!
  • 解锁游戏语言魔盒:XUnity.AutoTranslator让你的Unity游戏开口说中文