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

认证中心简介

单体应用体系下,应用是一个整体,一般针对所有的请求都会进行权限校验。请求一般会通过一个权限的拦截器进行权限的校验,在登录时将用户信息缓存到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. 粒度数据权限控制框架
相关推荐
于先生吖2 小时前
基于 Java 开发短剧系统:完整架构与核心功能实现
java·开发语言·架构
大鹏说大话2 小时前
云原生深水区:2026 年 Serverless 函数计算落地实战与成本极致优化
云原生·serverless
lpruoyu2 小时前
【云原生】可观测性系统—Istio
云原生·istio
lpruoyu2 小时前
【云原生】Harbor
云原生·harbor
lpruoyu2 小时前
【云原生】Kubernetes平台存储系统搭建_CRI、CNI、CSI
ceph·云原生·容器·kubernetes
jaysee-sjc3 小时前
十六、Java 网络编程全解析:UDP/TCP 通信 + BS/CS 架构
java·开发语言·网络·tcp/ip·算法·架构·udp
猹叉叉(学习版)3 小时前
【ASP.NET CORE】 14. RabbitMQ、洋葱架构
笔记·后端·架构·c#·rabbitmq·asp.net·.netcore
独断万古他化3 小时前
【抽奖系统开发实战】Spring Boot 抽奖系统全链路总结:从架构到落地的实践复盘
java·spring boot·后端·架构·系列总结
Gold Steps.3 小时前
GitOps之Jenkins 构建镜像自动更新 Helm 并触发 ArgoCD 自动同步
运维·ci/cd·云原生