四 过滤器
1 介绍
路由规则中,需定义路由器工厂的名字,以及其所用的参数,当请求进入网关后会按顺序执行各个过滤器的前置方法,放行给目的地,目的地处理请求后提交响应,响应会倒序经过每个过滤器的后置方法,最后返回给客户端。
2 路径重写过滤器 – 常用过滤器
① 作用:在请求转发到目标服务前,对原始路径进行灵活调整(如去除前缀、替换路径段等),此后无需再给每个服务方法增加基础路径,从而实现更灵活的路由匹配和服务治理。
② 删除OrderController,ProductFeignClient,ProductController之前设置的基础路径如/api/order
3 编写配置文件 – application-route.yml
匹配以 /api/product/ 开头
的路径,支持可选的末尾斜杠 /(? 表示前一个字符可选)。(?<segment>.*)
是命名捕获组,匹配 /product/ 后的任意内容(包括空字符串)。例如:/api/product/123 → 捕获 segment=123
替换模板:/$\{segment}
,将匹配到的路径重写为捕获组 segment 的内容。例如:/api/product/123 → /123
剥离请求路径中的 /api/product/ 部分,仅保留后续内容,实现网关层与后端服务的路径解耦
spring:
cloud:
gateway:
# 路由规则表 List
routes:
- id: dahuang-route # 请求路由名为 dahuang
uri: https://cn.bing.com/ # 全部符合后发到必应(Bing)搜索引擎
predicates: # 断言 需完全符合规定的请求进行转发 两个都要符合
- name: Path
args:
patterns: /search # 需访问网关的该路径
- name: Query # 可在其断言工厂查看能写那些参数
args:
param: q # 携带的参数名为 q
regexp: dahuang # 参数值为 dahuang
- Vip=user,xiaohuang
# - name: Vip
# args:
# param: user
# value: xiaohuang
order: 8
- id: product-route # 商品请求路由名
uri: lb://service-product
predicates: # 断言 符合规定的请求进行转发
- Path=/api/product/** # 请求路径开头相符转给 service-product
filters:
# RewritePath 过滤器的作用是 动态重写请求路径
- RewritePath=/api/product/?(?<segment>.*), /$\{
segment}
order: 1
- id: order-route # 订单请求路由名
uri: lb://service-order # lb 为负载均衡(Load Balancer)前缀格式
predicates: # 断言 符合规定的请求进行转发
- name: Path # 路径断言对应Path
args: # 所需参数 是个map
patterns: /api/order/**
matchTrailingSlash: true
order: 0
重启服务测试
4 添加自定义响应头过滤器 – 常用过滤器
① 尚未添加响应头
② 添加过滤器 – application-route.yml
spring:
cloud:
gateway:
# 路由规则表 List
routes:
- id: dahuang-route # 请求路由名为 dahuang
uri: https://cn.bing.com/ # 全部符合后发到必应(Bing)搜索引擎
predicates: # 断言 需完全符合规定的请求进行转发 两个都要符合
- name: Path
args:
patterns: /search # 需访问网关的该路径
- name: Query # 可在其断言工厂查看能写那些参数
args:
param: q # 携带的参数名为 q
regexp: dahuang # 参数值为 dahuang
- Vip=user,xiaohuang
# - name: Vip
# args:
# param: user
# value: xiaohuang
order: 8
- id: product-route # 商品请求路由名
uri: lb://service-product
predicates: # 断言 符合规定的请求进行转发
- Path=/api/product/**