GatewayFilter是网关中提供的一种过滤器,可以对进入网关的请求和微服务返回的响应做处理:
过滤器的作用:
对路由的请求或响应做加工处理,比如添加请求头配置在路由下的过滤器只对当前路由的请求生效defaultFilters的作用:
对所有路由都生效的过滤器 GatewayFilterFactory(过滤器工厂)Spring提供了31种不同的路由过滤器工厂
详细配置方式可以参考官方文档:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#gatewayfilter-factories
spring: application: name: gateway # 服务名称 cloud: nacos: server-addr: 127.0.0.1:80 # nacos地址 gateway: routes: # 网关路由配置 - id: user-service # 路由id,自定义,只要唯一即可 # uri: http://127.0.0.1:8081 # (1)路由的目标地址 http就是固定地址 uri: lb://userservice #(2,常用) 路由的目标地址 lb就是负载均衡,后面跟服务名称 predicates: # 路由断言,也就是判断请求是否符合路由规则的条件 - Path=/user/** # 这个是按照路径匹配,只要以/user/开头就符合要求# filters: #过滤器# - AddRequestHeader=Truth, bttc is freaking awesome! # 添加请求头 - id: order-service uri: lb://orderservice predicates: - Path=/order/** - Before=2031-01-20T17:42:47.789-07:00[Asia/Shanghai] default-filters:#默认过滤器 - AddRequestHeader=Truth, bttc niubi! # 添加请求头
全局过滤器全局过滤器的作用也是处理一切进入网关的请求和微服务响应,与GatewayFilter的作用一样。区别在于GatewayFilter通过配置定义,处理逻辑是固定的。而GlobalFilter的逻辑需要自己写代码实现。定义方式是实现GlobalFilter接口。
public interface GlobalFilter {Mono
定义全局过滤器,拦截并判断用户身份
需求:定义全局过滤器,拦截请求,判断请求的参数是否满足下面条件:
参数中是否有authorization,authorization参数值是否为admin
如果同时满足则放行,否则拦截
自定义类,实现GlobalFilter接口,添加@Order注解:
//过滤器执行优先级,值越小优先级越高@Order(-1)@Componentpublic class AuthorizeFilter implements GlobalFilter { @Override public Mono
请求进入网关会碰到三类过滤器:当前路由的过滤器、DefaultFilter、GlobalFilter
请求路由后,会将当前路由过滤器和DefaultFilter、GlobalFilter,合并到一个过滤器链(集合)中,排序后依次执行每个过滤器
每一个过滤器都必须指定一个int类型的order值,order值越小,优先级越高,执行顺序越靠前。GlobalFilter通过实现Ordered接口,或者添加@Order注解来指定order值,由我们自己指定路由过滤器和defaultFilter的order由Spring指定,默认是按照声明顺序从1递增。当过滤器的order值一样时,会按照 defaultFilter > 路由过滤器 > GlobalFilter的顺序执行。