【GateWay】网关详解和权限验证

  • 一、Gateway 核心概念与架构
  • 二、路由断言(Route Predicates)详解
  • 三、过滤器(Filters)机制
  • 四、权限认证的核心理论模型
  • 五、Spring Cloud Gateway + Security + OAuth2 集成方案
  • 六、OAuth2.0 集成

一、Gateway 核心概念与架构

Spring Cloud Gateway 是基于 Spring 5.0、Spring Boot 2.0 和 Project Reactor 构建的响应式 API 网关,核心功能包括:

  • 路由转发:根据请求条件将请求转发到不同微服务
  • 请求过滤:在请求或响应处理过程中添加自定义逻辑
  • 动态路由:结合服务注册中心实现路由配置动态更新
  • 流量控制:支持限流、熔断等服务保护机制

其架构基于 Reactor 响应式编程模型,采用非阻塞 IO,相比传统阻塞式网关(如 Zuul 1.x)具有更高的并发处理能力。

二、路由断言(Route Predicates)详解

1. 路由断言的本质
路由断言是 Gateway 用于匹配请求的条件表达式,通过一组预定义的谓词(Predicate)判断请求是否符合路由规则。
每个路由至少包含一个断言,当请求满足所有断言时,才会被转发到目标服务。

2. 常用路由断言谓词

断言类型作用描述配置示例
Path匹配请求路径模式Path=/user-service/**
Method匹配 HTTP 请求方法(GET、POST 等)Method=GET
Header匹配请求头中的参数Header=X-Request-Id, \d+
Query匹配请求参数Query=name, Jack
Cookie匹配请求 CookieCookie=JSESSIONID, [a-z0-9]+
Host匹配请求 Host 头Host=**.example.com
RemoteAddr匹配客户端IP 地址 RemoteAddr=192.168.1.1/24
TimeBetween匹配请求时间范围TimeBetween=8:00-18:00
Weight权重路由(配合负载均衡)Weight=group1, 80

3. 断言组合与优先级

  • 组合方式:多个断言通过 AND 逻辑组合(需同时满足),例如:
  • 优先级:路由配置的顺序决定断言匹配优先级,先匹配的路由优先处理
- Path=/api/user/** AND Method=GET

4. 自定义断言
若需扩展断言逻辑,可实现 GatewayPredicateFactory 接口,例如:

public class CustomPredicateFactory extends AbstractGatewayPredicateFactory<CustomPredicateFactory.Config> {public CustomPredicateFactory() {super(Config.class);}@Overridepublic GatewayPredicate apply(Config config) {return (exchange, chain) -> {// 自定义断言逻辑(如请求参数校验、用户身份验证等)return chain.filter(exchange);};}public static class Config {// 断言配置参数}
}

三、过滤器(Filters)机制

1. 过滤器分类
Gateway 过滤器分为两类:

  • 内置过滤器:Gateway 自带的功能过滤器,覆盖常见需求
  • 自定义过滤器:用户根据业务需求自定义的过滤器

2. 核心内置过滤器

过滤器类型作用描述配置示例
RewritePath重写请求路径RewritePath=/api/(?.*), /${segment}
Retry请求重试机制Retry=3, BAD_GATEWAY, 1000
Hystrix集成 Hystrix 熔断Hystrix=myCommand
RequestRateLimiter请求限流(基于 Redis)RequestRateLimiter=10, 20, 100
CircuitBreaker 熔断处理(支持 Sentinel 等)CircuitBreaker=mybreaker
ResponseHeader修改响应头ResponseHeader=X-Result, Success
RequestHeader修改请求头RequestHeader=X-User, ${user}

3. 过滤器执行流程

  • Pre 过滤器:在请求转发到目标服务前执行(如权限验证、参数校验)
  • Post 过滤器:在目标服务响应后执行(如结果转换、响应头添加)
  • 执行顺序:过滤器按配置顺序执行,可通过 order() 方法指定优先级

4. 自定义过滤器实现

@Component
public class AuthFilter implements GlobalFilter, Ordered {@Overridepublic Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {// 1. 从请求中获取令牌String token = exchange.getRequest().getHeaders().getFirst("Authorization");// 2. 令牌验证逻辑if (token == null || !validateToken(token)) {ServerHttpResponse response = exchange.getResponse();response.setStatusCode(HttpStatus.UNAUTHORIZED);return response.setComplete();}// 3. 验证通过,放行请求return chain.filter(exchange);}@Overridepublic int getOrder() {return 0; // 过滤器优先级,数值越小优先级越高}private boolean validateToken(String token) {// 令牌验证逻辑(可对接 OAuth2、JWT 等)return true;}
}

四、权限认证的核心理论模型

在微服务架构中,权限认证遵循 “认证(Authentication)+ 授权(Authorization)” 分离的原则:

  1. 认证(Authentication)
    验证用户身份的合法性,常见方式:
  • 用户名 / 密码
  • Token(如 JWT、OAuth2 Access Token)
  • 生物特征(指纹、人脸等)
  1. 授权(Authorization)
    验证用户是否有权限访问特定资源,基于:
  • 角色(Role):如 ADMIN、USER
  • 权限(Permission):如 USER_CREATE、ORDER_VIEW
  • 属性(Attribute):如用户部门、地域
  1. OAuth2.0 协议模型
  • 资源所有者(Resource Owner):用户
  • 客户端(Client):前端应用或第三方服务
  • 授权服务器(Authorization Server):颁发令牌
  • 资源服务器(Resource Server):保护受保护资源
  1. JWT 令牌结构
    JWT 由三部分组成:

Header.Payload.Signature
头部 . 有效载荷 . 签名

  • Header:包含令牌类型和签名算法
  • Payload:包含声明(Claims),如用户 ID、角色、过期时间
  • Signature:使用密钥对 Header 和 Payload 签名生成

五、Spring Cloud Gateway + Security + OAuth2 集成方案

┌─────────────────────────────────────────────────────────┐
│                    客户端请求                             │
└───────────────────────┬─────────────────────────────────┘│▼
┌─────────────────────────────────────────────────────────┐
│                 Spring Cloud Gateway                     │
│  ┌─────────────────────────────────────────────────────┐│
│  │                   Security 过滤器链                   ││
│  │  ┌───────────┐  ┌───────────┐  ┌──────────────────┐ ││
│  │  │ 认证过滤器 │→│ 授权过滤器 │→│ OAuth2资源服务器过滤器 │ │
│  │  └───────────┘  └───────────┘  └──────────────────┘ ││
│  └─────────────────────────────────────────────────────┘│
└───────────────────────┬─────────────────────────────────┘│▼
┌─────────────────────────────────────────────────────────┐
│                 下游微服务集群                             │
└─────────────────────────────────────────────────────────┘

六、OAuth2.0 集成

1. OAuth2 授权模式选择

模式适用场景安全性
授权码模式 (Authorization Code)服务端应用(如 Web 应用)最高
简化模式 (Implicit)前端应用(如 SPA)中等
密码模式 (Resource Owner Password Credentials)受信任的第一方应用中等
客户端模式 (Client Credentials)服务间调用

2. 资源服务器配置

spring:security:oauth2:resourceserver:jwt:issuer-uri: http://auth-server:8080  # 授权服务器URLjwk-set-uri: http://auth-server:8080/oauth2/jwks  # JWK集合URL

3. 令牌自省(Token Introspection)
当使用 opaque token(非 JWT)时,需配置令牌自省端点:

spring:security:oauth2:resourceserver:introspection-uri: http://auth-server:8080/oauth2/introspect  # 自省端点client-id: resource-server  # 资源服务器IDclient-secret: secret  # 资源服务器密钥

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/87576.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/87576.shtml
英文地址,请注明出处:http://en.pswp.cn/diannao/87576.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

QSqlDatabase: QSQLITE driver not loaded

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言可能的原因解决办法1. 确认 SQLite 驱动插件文件2. 拷贝插件文件到应用程序目录3. 设置插件搜索路径4. 安装 SQLite 依赖库5. 解决 QCoreApplication 实例问题 …

20250619在荣品的PRO-RK3566开发板的Android13下解决海罗光电有限公司HL070T58C-05屏在启动的时候出现白色条纹的问题【时序】

20250619在荣品的PRO-RK3566开发板的Android13下解决海罗光电有限公司HL070T58C-05屏在启动的时候出现白色条纹的问题 2025/6/19 20:39 缘起&#xff1a;荣品的PRO-RK3566开发板的Android13下&#xff0c;点亮海罗光电有限公司HL070T58C-05屏。 在启动的时候会出现花屏/白色条纹…

docker使用Volume对Nginx进行挂载

需求&#xff1a; 需要将Nginx的欢迎页面也就是index.html文件进行修改。 原始方法&#xff1a;由于docker会为每一个容器创建其对应的文件信息&#xff0c;但是创建的信息内容只有其最基础的运行信息&#xff0c;所以想要直接去访问其index.html就无法做到。 使用volume&am…

基于springboot的宠物服务预约系统

博主介绍&#xff1a;java高级开发&#xff0c;从事互联网行业六年&#xff0c;熟悉各种主流语言&#xff0c;精通java、python、php、爬虫、web开发&#xff0c;已经做了六年的毕业设计程序开发&#xff0c;开发过上千套毕业设计程序&#xff0c;没有什么华丽的语言&#xff0…

idea 2025会在用户目录创建IdeaSnapshots文件夹

推荐一个api管理测试工具 一个简单的API测试和编写文档的工具 idea 2025会在用户目录创建IdeaSnapshots文件夹 解决方案 打开 Profiler 点击 setting 参考 https://youtrack.jetbrains.com/articles/SUPPORT-A-1086/How-to-change-or-turn-off-the-IdeaSnapshots-folder-…

【Mini-F5265-OB开发板试用测评】2、PWM驱动遥控车RX2接收解码带马达驱动控制IC

手头有带转向电机和动力电机小车底盘&#xff0c;买了很久一直在吃灰。 最近查了一下小车的驱动IC是富满微的8D420L,是一款传统的RX2接收解码芯片&#xff0c;带马达驱动。 手头没有TX2发送芯片&#xff0c;所以考虑用MCU直接发送PWM直接接入RX2&#xff0c;可能可以驱动。 一…

Tcpdump网络抓包工具详解!

一、简介 tcpdump就是&#xff1a;dump the traffic on a network&#xff0c;根据使用者的定义对网络上的数据包进行截获的包分析工具。 tcpdump是一个用于截取网络分组&#xff0c;并输出分组内容的工具。凭借强大的功能和灵活的截取策略&#xff0c;使其成为类UNIX系统下用…

Spring Boot的Security安全控制——应用SpringSecurity!

应用Spring Security 前面介绍了在项目开发时为什么选择Spring Security&#xff0c;还介绍了它的原理。本节开始动手实践Spring Security的相关技术。 实战&#xff1a;Spring Security入门 现在开始搭建一个新项目&#xff0c;实践一个Spring Security的入门程序。 &…

FPGA基础 -- Verilog行为级建模之alawys语句

Verilog 中的 always 语句块&#xff0c;这是行为级建模的核心结构之一&#xff0c;在 RTL 级设计中广泛用于时序逻辑和组合逻辑的建模。 一、什么是 always 语句&#xff1f; ✅ 定义&#xff1a; always 语句用于描述可综合的硬件行为逻辑&#xff0c;表示一个**“事件驱动…

【力扣 简单 C】704. 二分查找

目录 题目 解法一&#xff1a;二分查找 题目 解法一&#xff1a;二分查找 int find(const int* nums, int size, int target) {int left 0, right size - 1;while (left < right){int mid (left right) / 2;if (nums[mid] < target)left left 1;else if (nums[m…

Java并发编程实战 Day 30:并发编程未来展望与最佳实践总结

【Java并发编程实战 Day 30】并发编程未来展望与最佳实践总结 文章简述 经过30天的系统学习&#xff0c;我们从Java并发编程的基础知识逐步深入到高并发系统的架构设计与性能优化。本文作为“Java并发编程实战”系列的收官之作&#xff0c;将全面回顾整个系列的核心内容&#…

量化面试绿皮书:23. 醉酒乘客

文中内容仅限技术学习与代码实践参考&#xff0c;市场存在不确定性&#xff0c;技术分析需谨慎验证&#xff0c;不构成任何投资建议。 23. 醉酒乘客 100名乘客排队登机&#xff0c;每人持有一张对应座位的机票&#xff08;第n位乘客的座位号为n&#xff09;。 第一位乘客喝醉后…

AntV G6入门教程

以下教程聚焦于 AntV G6 的 数据操作 API,详细介绍各个方法的用途、参数以及完整的使用示例,帮助你在图实例上精细地读取、修改和管理节点/边/组合等数据。文中示例代码均基于 G6 v5.0.47 官方文档 ([g6.antv.antgroup.com][1])。 一、获取完整图数据 1.1 graph.getData() …

67、数据访问-crud实验-分页数据展示

67、数据访问-crud实验-分页数据展示 分页数据展示是数据访问中常见的功能&#xff0c;用于将大量数据分割成多个页面显示&#xff0c;提升用户体验和系统性能。以下是分页数据展示的相关介绍&#xff1a; #### 基本原理 1. **确定每页显示数量**&#xff1a;设定每页显示的数…

常见 Web 服务器

Web 服务器有很多种&#xff0c;功能和用途略有不同&#xff0c;下面我会分类介绍主流的 Web 服务器&#xff08;包含静态/动态/反向代理支持&#xff09;并重点说明类似 Tomcat 的 Java 支持型。 常见 Web 服务器分类 类型名称描述与特点&#x1f310; 静态资源服务器Nginx高…

【MacOS】M3 Pro芯片MacBook极速搭建Kubernetes

M3 Pro 芯片 MacBook 2023上使用 Colima 安装 Kubernetes。 Colima 轻量、高效&#xff0c;并且在 Apple Silicon 架构上表现出色。 下面是详细的、一步一步的安装和配置指南。 核心思路 我们将通过以下步骤完成整个过程&#xff1a; 准备工作: 安装必要的工具&#xff0c;…

import { Add, Dongdong, UserAdd } from ‘@nutui/icons-react‘ 使用图标导入库报错

import { Add } from "nutui/icons-react-taro"; 官网的导入的库名字不全&#xff0c;后面要加-taro&#xff0c;就行了

猿人学js逆向比赛第一届第七题

分析响应 看到响应体里面的data是个字体加密&#xff0c;于是这里可以看到woff文件也给返回了&#xff0c;这里现分析这个文件。 打开可以看到这里a351对应的是3和页面中的3是对应的&#xff0c;于是用ddddocr动态识别字体文件中的字体&#xff0c;然后对应对应的字体替换是不…

股票心理学习篇:交易的人性弱点 - 频繁交易

以下内容为学习时的笔记整理&#xff0c;视频作者来自B站&#xff1a;老猫与指标 视频链接&#xff1a;频繁交易必死&#xff1f;底层逻辑深度剖析&#xff0c;老猫的的破局心法与实战策略分享 交易的人性弱点 - 频繁交易 主讲人&#xff1a; 老猫 1. 引言&#xff1a;问题的…

WPF入门 #1 WPF布局基础、WPF样式基础、WPF数据模板、WPF绑定

WPF当中有许多的布局容器控件&#xff0c;例如<Grid>、<StackPanel>、<WrapPanel>、<DockPanel>、<UniformGrid>。接下来分别介绍一下各个布局容器控件。 布局基础 Grid <Grid><Grid.RowDefinitions><RowDefinition Height&qu…