SpringCloud Gateway自定义断言功能

1.在服务网关的application.yml文 件中的 spring.cloud.gateway.routes 节点下的 - id: user-gateway 下面进行如下配置

spring :
         cloud :
                 gateway :
                         routes :
                                 - id : cloud-gateway 
                        ​​​​​​​        ​​​​​​​   uri : http : //localhost : 8080
                        ​​​​​​​        ​​​​​​​   order : 1
                ​​​​​​​        ​​​​​​​           predicates :
                ​​​​​​​        ​​​​​​​        ​​​​​​​         - Path=/cloud-user/**
                ​​​​​​​        ​​​​​​​        ​​​​​​​         - Name=lq   //此处是重点
通过服务网关访问用户微服务时,只有在访问的链接后面添加 ?name=lq 参数时才能正确访问用户
微服务。
2.创建一个类, 接收配置文件中的参数
@Data
public class NameRoutePredicateConfig implements Serializable {
private static final long serialVersionUID = - 3289515863495274396L ;
private String name ;
} ​​​​​​​
3.创建 NameRoutePredicateFactory类,实现 AbstractRoutePredicateFactory类 覆写相关的方法。
@Component
public class NameRoutePredicateFactory extends
AbstractRoutePredicateFactory < NameRoutePredicateConfig > {
public NameRoutePredicateFactory () {
super ( NameRoutePredicateConfig . class );
}
@Override
public Predicate < ServerWebExchange > apply ( NameRoutePredicateConfig config ) {
return ( serverWebExchange ) -> {
String name =
serverWebExchange . getRequest (). getQueryParams (). getFirst ( "name" );
if ( StringUtils . isEmpty ( name )){
name = "" ;
}
return name . equals ( config . getName ());
};
}
@Override
public List < String > shortcutFieldOrder () {
return Arrays . asList ( "name" );
}
}
4.在浏览器输入以下格式的地址,才能获取到相应的信息
http://localhost:8080/cloud - user/user/get/1234?name=lq
                ​​​​​
  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Spring Cloud Gateway的一些优点包括: 1. 灵活性:Spring Cloud Gateway是基于Spring框架构建的,因此可以充分利用Spring生态系统中的各种特性和库。它提供了很多强大的扩展机制,如过滤器、断言等,可以根据自己的需求灵活地定制和扩展网关的行为。 2. 性能优化:Spring Cloud Gateway采用了基于Netty的异步非阻塞架构,可以支持高并发场景,并且具有较低的资源消耗。它还支持异步IO、零拷贝等技术,提高了请求处理的效率和吞吐量。 3. 集成性:Spring Cloud Gateway与Spring Cloud整合紧密,可以无缝地集成其他Spring Cloud组件,如服务发现、负载均衡等。它还支持动态路由配置、熔断降级、限流等常用微服务治理功能,可以方便地与现有的微服务架构进行集成。 4. 响应式编程:Spring Cloud Gateway基于响应式编程模型,可以利用Reactor库提供的响应式操作符进行请求处理和响应转换。这使得开发人员能够更加方便地处理异步和并发场景,提高系统的可伸缩性和性能。 5. 可扩展性:Spring Cloud Gateway支持自定义的过滤器和断言,开发人员可以根据自己的需求自定义和扩展网关的功能。此外,它还支持多种路由匹配方式,包括基于路径、基于请求头、基于Host等,可以满足不同场景下的需求。 总的来说,Spring Cloud Gateway是一个功能强大、灵活性高、性能优化的网关框架,适用于构建微服务架构中的API网关,帮助开发人员实现统一的请求路由、安全控制、流量管理等功能

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值