SpringCloud Gateway自定义路由过滤器

当官方提供的过滤器不能满足业务需求,可以自定义路由过滤器。

添加自定过滤器类

自定义过滤器工厂需要注意以下几点:

  • 需要声明是Springboot的Bean,添加注解@Component,名称必须以GatewayFilterFactory结尾,这个是命名约束。
  • 如果不按照命名约束来命名,那么就会找不到该过滤器工厂。前缀就是配置中配置的断言。
  • 可以直接复制Gateway中已经实现的过滤器工厂,修改对应的内容,避免踩坑。
  • 继承父类AbstractGatewayFilterFactory,并重写方法。
  • 需要定义一个Config静态内部类,来接收断言配置的数据。
  • 在重写的shortcutFieldOrder方法中,绑定Config中的属性。传入数组的内容需要与Config中的属性一致。
  • 在重写的apply方法中,实现过滤器具体业务逻辑。
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.cloud.gateway.filter.GatewayFilter;
import org.springframework.cloud.gateway.filter.factory.AbstractGatewayFilterFactory;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.stereotype.Component;

import java.util.Arrays;
import java.util.List;

/**
 * @ClassName CustomGatewayFilterFactory
 * @Description
 * @Author tigerkin
 * @Date 2022/3/14 16:24
 */
@Component
public class CustomGatewayFilterFactory extends AbstractGatewayFilterFactory<CustomGatewayFilterFactory.Config> {

    /**
     * Filter key.
     */
    public static final String FILTER_KEY = "filterKey";

    /**
     * Filter key.
     */
    public static final String FILTER_VAL = "filterVal";

    private final Logger log = LoggerFactory.getLogger(this.getClass());

    public CustomGatewayFilterFactory() {
        super(CustomGatewayFilterFactory.Config.class);
    }

    @Override
    public List<String> shortcutFieldOrder() {
        return Arrays.asList(FILTER_KEY, FILTER_VAL);
    }

    @Override
    public GatewayFilter apply(CustomGatewayFilterFactory.Config config) {
        /**
         * 可以是用lamda表达式,也可以new GatewayFilter() {}
         */
        return (exchange, chain) -> {
            log.info("========> 进入自定义过滤器 key:{} val:{}", config.getFilterKey(), config.getFilterVal());

            ServerHttpRequest request = exchange.getRequest();
            log.info("========> 请求内容 url:{} method:{} param:{} headers:{}",
                    request.getURI(), request.getMethodValue(), request.getQueryParams(), request.getHeaders());
            return chain.filter(exchange);
        };
    }

    public static class Config {

        private String filterKey;

        private String filterVal;

        public String getFilterKey() {
            return filterKey;
        }

        public void setFilterKey(String filterKey) {
            this.filterKey = filterKey;
        }

        public String getFilterVal() {
            return filterVal;
        }

        public void setFilterVal(String filterVal) {
            this.filterVal = filterVal;
        }
    }
}

配置自定义的过滤器

spring:
  cloud:
    gateway:
      routes:
        - id: user-route # 路由ID,唯一标识,自定义命名
          uri: lb://gateway-user
          predicates:
            - Path=/user-server/**
            # 自定义的断言工厂,多个参数按逗号(,)隔开,参数对应断言工厂中shortcutFieldOrder方法定义的数组,一一对应。
            - CustomVerify=verify, success 
          filters:
            - StripPrefix=1
            # 自定义过滤器配置,与断言工厂一致
            - Custom=filter, custom

自定义路由过滤配置完成

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud Gateway是基于Spring Framework 5,Spring Boot 2和Project Reactor等技术构建的网关,它提供了一些强大的路由功能,可以用于构建微服务应用程序。 Spring Cloud Gateway中的过滤器(Filter)是一个非常重要的组件,可以用来对进入网关的请求进行处理,例如身份验证、日志记录、限流等。Spring Cloud Gateway支持两种类型的过滤器:全局过滤器路由过滤器。其中全局过滤器将会应用到所有的路由上,而路由过滤器只会应用到指定的路由上。 下面是Spring Cloud Gateway自定义过滤器的流程: 1. 创建一个类,实现org.springframework.cloud.gateway.filter.GlobalFilter接口或者org.springframework.cloud.gateway.filter.GatewayFilter接口。 2. 实现接口中的filter方法,该方法接收一个ServerWebExchange对象和一个GatewayFilterChain对象作为参数。ServerWebExchange对象表示当前请求和响应的上下文信息,GatewayFilterChain对象表示当前过滤器链。 3. 在filter方法中编写自己的业务逻辑,例如身份验证、日志记录、限流等。 4. 如果实现的是全局过滤器,则需要在应用启动类中注册该过滤器。可以通过@Bean注解将该过滤器注入到Spring容器中。 5. 如果实现的是路由过滤器,则需要在定义路由的配置中注册该过滤器。可以通过GatewayFilterSpec类的filter方法将该过滤器添加到路由过滤器链中。 6. 启动应用程序,测试自定义过滤器是否生效。 以上就是Spring Cloud Gateway自定义过滤器的流程,通过自定义过滤器可以实现更加灵活、高效的网关应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值