gateway网关结合nacos动态路由

一,环境配置

		<dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-gateway</artifactId>
            <version>2.2.3.RELEASE</version>
        </dependency>

启动类加注解@EnableDiscoveryClient注册到nacos注册中心。

application.properties配置

spring.application.name=digitaltwins-api
server.port=8082
spring.cloud.nacos.discovery.server-addr=192.168.1.182:8848
spring.cloud.gateway.discovery.locator.enabled=true

spring.cloud.gateway.discovery.locator.enabled=true

这个配置是动态路由开启,自动识别nacos的服务名进行路由

比如:订单服务的nacos注册的服务名是test-order,那么从网关访问订单服务的地址是http://127.0.0.1:8080/test-order/xxxx/xxxx

二,自定义全局过滤器

网关路由请求过后,如果我们希望拦截请求,做自己的业务逻辑则可以使用GlobalFilter 全局过滤器

全局过滤器的作用也是处理一切进入网关的请求和微服务响应,与 GatewayFilter 的作用一样。区别在于 GlobalFilter 的逻辑可以写代码来自定义规则;而 GatewayFilter 通过配置定义,处理逻辑是固定的。

**需求:**定义全局过滤器,拦截请求,判断请求的参数是否满足下面条件

  • 参数中是否有 authorization
  • authorization 参数值是否为 admin

如果同时满足则放行,否则拦截

三,自定义局部管理器

需求:在过滤器(MyParamGatewayFilterFactory)中将http://localhost:10010/user/8?name=yh 中的参数name的值获取到并输出到控制台

在application.yml文件中添加gateway过滤器:

建立一个文件config,创建名为MyParamGatewayFiterFactory的类
注意!命名xxxxGatewayFiterFactory,xxxx为yml自定义的名称+GatewayFiterFactory;GatewayFiterFactory没有或者出错会出现以下错误

将MyParamGatewayFiterFactory继承父类AbstractGatewayFilterFactory<MyParamGatewayFiterFactory.Config>并添加@Component注解

创建一个Config类用来读取过滤器配置的参数,在类中创建一个String类型的参数对应配置在application.yml配置文件中的过滤器参数名,并生成get set方法

重写父类的方法:

重写父类GatewayFilter方法,由源码可看出要求返回类型为
ServerWebExchange exchange, GatewayFilterChain chain

完整

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值