- springcloudgateway作用
- 路由转发
- 过滤器
过滤器jeecg 路由加载支持三种模式:yml本地配置 、 nacos配置 、 database数据库,其中nacos和数据库方式支持动态刷新路由!默认用的是database数据库模式。
全局过滤器和局部过滤器
全局过滤器:实现GlobalFilter接口定义全局过滤器,实现Ordered 接口定义多个过滤器之间的执行顺序
// An highlighted block
@Component
public class LoginFilter1 implements GlobalFilter, Ordered {
@Override
public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) {
System.out.println("执行了自定义的全局过滤器---1");
return chain.filter(exchange); //继续向下执行
}
@Override
public int getOrder() {
return 1;
}
}
局部过滤器:对于自定义的factory,我们可以选择去实现接口或继承已有的抽象类,相关的接口是GatewayFilterFactory,而springboot默认帮我们实现的抽象类是AbstractGatewayFilterFactory这个;
注意我们通过这种工厂创建出来的过滤器是没有指定order的,会被默认设置为是0,配置在yml文件中,则按照它书写的顺序来执行;
然后是yaml的配置,这里需要注意的是,之前我一直失败,在调用gateway会报告找不到对应的过滤率,这是因为命名导致的;
springboot约定过滤器的前缀为配置的name,而后面最好统一都是GatewayFilterFactory
// An highlighted block
@Component
public class LoginGatewayFilterFactory extends AbstractGatewayFilterFactory {
@Override
public GatewayFilter apply(Object config) {
return (exchange, chain) -> {
exchange.getAttributes().put("attrbute_time", System.currentTimeMillis());
return chain.filter(exchange).then(
Mono.fromRunnable(() -> {
Long startTime = exchange.getAttribute("attrbute_time");
if (startTime != null) {
StringBuilder sb = new StringBuilder(exchange.getRequest().getURI().getRawPath())
.append("---此接口耗时")
.append(": ")
.append(System.currentTimeMillis() - startTime)
.append("ms");
}
})
);
};
}
}
因为我使用的是springboot,那么需要在启动类里,将这个工厂注入到spring容器当中
要么如下使用@Bean注解,要么使用@Component注解
// An highlighted block
@Bean
public ExampleGatewayFilterFactory exampleGatewayFilterFactory(){
return new ExampleGatewayFilterFactory();
}
默认过滤器:对所有路由都生效的过滤器
// An highlighted block
default-filters:
- Login
前置过滤器和后置过滤器
前置过滤器普通实现即可;
后置过滤器需注意:
return chain.filter(exchange).then(
Mono.fromRunnable(() -> {}));



