网关过滤器

简介: 网关鉴权需在请求转发前完成。通过理解Gateway原理,利用GlobalFilter或GatewayFilter,在NettyRoutingFilter之前执行身份校验,实现安全控制。过滤器通过pre逻辑拦截请求,确保鉴权通过后才路由至微服务,保障系统安全。

网关鉴权必须在请求转发到微服务之前做,否则就失去了意义。而网关的请求转发是Gateway内部代码实现的,要想在请求转发之前做身份校验,就必须了解Gateway内部工作的基本原理。

  1. 客户端请求进入网关后由HandlerMapping对请求做判断,找到与当前请求匹配的路由规则(Route),然后将请求交给WebHandler去处理。
  2. WebHandler则会加载当前路由下需要执行的过滤器链(Filter chain),然后按照顺序逐一执行过滤器(后面称为Filter)。
  3. Filter内部的逻辑分为pre和post两部分,分别会在请求路由到微服务之前和之后被执行。
  4. 只有所有Filter的pre逻辑都依次顺序执行通过后,请求才会被路由到微服务。
  5. 微服务返回结果后,再倒序执行Filter的post逻辑。
  6. 最终把响应结果返回。
    最终请求转发是有一个名为NettyRoutingFilter的过滤器来执行的,而且这个过滤器是整个过滤器链中顺序最靠后的一个。如果我们能够定义一个过滤器,在其中实现身份校验逻辑,并且将过滤器执行顺序定义到NettyRoutingFilter之前,这就符合我们的需求了!
    那么,该如何实现一个网关过滤器呢?
    网关过滤器链中的过滤器有两种:
    ● GatewayFilter:路由过滤器,作用范围比较灵活,可以是任意指定的路由Route.
    ● GlobalFilter:全局过滤器,作用范围是所有路由,不可配置。
    其实GatewayFilter和GlobalFilter这两种过滤器的方法签名完全一致:
    /**
    • 处理请求并将其传递给下一个过滤器
    • @param exchange 当前请求的上下文,其中包含request、response等各种数据
    • @param chain 过滤器链,基于它向下传递请求
    • @return 根据返回值标记当前请求是否被完成或拦截,chain.filter(exchange)就放行了。
      */
      Mono filter(ServerWebExchange exchange, GatewayFilterChain chain);
      FilteringWebHandler在处理请求时,会将GlobalFilter装饰为GatewayFilter,然后放到过滤器链中,排序以后依次执行。
相关文章
|
5月前
|
人工智能 安全 Java
网关鉴权
微服务架构下,用户身份校验需统一处理。基于JWT的网关鉴权将认证集中于网关,避免密钥泄露与代码重复。网关校验Token并透传用户信息,微服务专注权限控制,通过Spring Security注解如`hasAuthority`实现细粒度授权,提升安全与可维护性。(238字)
|
5月前
|
安全 算法 Java
内置过滤器
Spring Cloud Gateway内置多种GatewayFilter,用于请求路由、过滤与响应处理,如AddRequestHeader、StripPrefix等,可灵活实现路径重写、请求限流等功能,结合路由配置满足各类微服务场景需求。
|
2月前
|
Java 关系型数据库 MySQL
服务注册发现深度拆解:Nacos vs Eureka 核心原理、架构选型与生产落地
本文深度解析微服务注册发现核心原理,对比Eureka(AP优先、简单稳定)与Nacos(AP/CP双模、功能丰富、性能更强)的架构、机制与适用场景,涵盖6大核心能力、集群同步、健康检查、服务发现模式等,并提供生产级代码实践与选型避坑指南。
358 2
|
3月前
|
存储 Java 中间件
Java 虚拟线程:JDK21 轻量级并发革命
JDK21正式引入的虚拟线程是Java并发模型的革命性升级:轻量(百字节/个)、百万级可扩展、JVM自主调度、零OS上下文切换,完美解决传统平台线程内存高、并发低、调优难痛点,尤其适用于IO密集型微服务与网关场景。
423 4
|
2月前
|
算法 Java Sentinel
高可用架构核心:限流熔断降级全解,Sentinel 与 Resilience4j 原理 + 落地实战
本文深入解析分布式系统高可用三大核心手段——限流、熔断、降级的本质与边界,对比剖析Sentinel(全链路流量治理)与Resilience4j(轻量函数式容错)的底层原理、实战配置及选型策略,并提供生产环境最佳实践与避坑指南。
508 1
|
5月前
|
人工智能 自然语言处理 安全
MCP的核心组件
MCP采用客户端-服务器架构,由MCP主机、客户端和服务器组成。主机承载AI智能体并发起请求;客户端负责请求标准化与安全通信;服务器提供数据、工具和提示,支持AI实时访问外部资源与服务,实现高效交互。
|
5月前
|
机器学习/深度学习 数据采集 人工智能
大模型训练方法与技术术语解释
预训练奠定语言基础,微调适配特定任务,RLHF融入人类偏好,思维链提升推理能力。少样本与零样本实现快速迁移,指令微调增强指令理解。自监督学习利用海量无标注数据,温度控制生成随机性,蒸馏压缩模型规模,缩放定律指导模型扩展,共同推动大模型发展。
|
存储 Kubernetes 调度
Kubernetes、Docker和Containerd的关系解析
总的来说,Docker、Containerd和Kubernetes之间的关系可以用一个形象的比喻来描述:Docker就像是一辆装满货物的卡车,Containerd就像是卡车的引擎,而Kubernetes就像是调度中心,负责指挥卡车何时何地送货。
523 12
|
Kubernetes 负载均衡 开发者
在K8S中,Kubernetes与Docker有什么关系?
在K8S中,Kubernetes与Docker有什么关系?
linux中 grep过滤查找 及 管道 ”|” 的使用
linux中 grep过滤查找 及 管道 ”|” 的使用