28.Gateway-网关过滤器

GatewayFilter是网关中提供的一种过滤器,可以多进入网关的请求和微服务返回的响应做处理。

GatewayFilter(当前路由过滤器,DefaultFilter)

spring中提供了31种不同的路由过滤器工厂。

filters针对部分路由的过滤器。

default-filters针对所有路由的默认过滤器。

java 复制代码
server:
  port: 10010 # 网关端口
spring:
  application:
    name: gateway # 服务名称
  cloud:
    nacos:
      server-addr: localhost:8848 # nacos 地址
    gateway:
      routes:
        - id: user-service # 路由id,自定义,只要唯一即可
          uri: lb://user-service # 路由的目标地址lb是负载均衡,后面跟服务名称
          predicates: # 路由断言,判断请求是否符合路由的规则的条件
            - Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求
        - id: order-service
          uri: lb://order-service
          predicates:
            - Path=/order/**
          filters: # 过滤器,只对order-service的路由请求生效
            - AddRequestHeader=truth,xkj will be success. # 添加请求头
      default-filters: # 默认过滤器,会对所有的路由请求都生效
        - AddRequestHeader=common,everyone can be success.

@RequestHeader获取请求头中的数据

java 复制代码
@GetMapping("{orderId}")
    public Order queryOrderByUserId(@PathVariable("orderId") Long orderId, @RequestHeader("truth") String truth) {
        log.info("truth={}",truth);
        return orderService.queryOrderById(orderId);
    }
相关推荐
SimonKing6 分钟前
OpenCode 在 IDEA 中使用 ACP 协议 VS 直接使用 TUI,哪个编程方式更是你的菜?
java·后端·程序员
NE_STOP14 分钟前
Redis--持久化之AOF
java
budingxiaomoli15 分钟前
注册中心的其他实现-Nacos
java·spring cloud·微服务
大大大大晴天️26 分钟前
Flink技术实践-Flink重启策略选型指南
java·大数据·flink
ffqws_31 分钟前
Spring @Transactional 注解详解:从入门到避坑
java·数据库·后端·spring
xuhaoyu_cpp_java33 分钟前
单调栈(算法)
java·数据结构·经验分享·笔记·学习·算法
黑夜里的小夜莺1 小时前
黑马点评登录成功后点击【我的】会跳转到登录页面 BUG 修复
java·bug
wuyikeer1 小时前
Java进阶——IO 流
java·开发语言·python
fengxin_rou1 小时前
JVM 内存结构与内存溢出 / 泄漏问题全解析
java·开发语言·jvm·分布式·rabbitmq
城俊BLOG1 小时前
C++的注册机制和插件系统
java·服务器·c++