java - Spring boot 2.3.1 和 Spring cloud gatewat 2.2.1 ;找不到名称为 CustomFilterName 的 GatewayFilterFactory
问题描述
我创建了一个名为“CustomFilterName”的自定义过滤器,下面是我的配置和 java 文件。
收到错误:
reactor.core.Exceptions$ErrorCallbackNotImplemented:java.lang.IllegalArgumentException:无法找到名称为 CustomFilterName 的 GatewayFilterFactory 原因:java.lang.IllegalArgumentException:无法找到名称为 CustomFilterName 的 GatewayFilterFactory
在 org.springframework.cloud.gateway.route.RouteDefinitionRouteLocator.loadGatewayFilters(RouteDefinitionRouteLocator.java:180) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE] 在 org.springframework。 cloud.gateway.route.RouteDefinitionRouteLocator.getFilters(RouteDefinitionRouteLocator.java:226) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE] at org.springframework.cloud.gateway.route .RouteDefinitionRouteLocator.convertToRoute(RouteDefinitionRouteLocator.java:163) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE] at reactor.core.publisher.FluxMap$MapSubscriber.onNext(FluxMap. java:100) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxFlatMap$FlatMapMain.drainLoop(FluxFlatMap.java:704) ~[reactor-core-3.3 .6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher。FluxFlatMap$FlatMapMain.drain(FluxFlatMap.java:580) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] at reactor.core.publisher.FluxFlatMap$FlatMapInner.onSubscribe(FluxFlatMap.java:970 ) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable.java:161) ~[reactor-core-3.3.6.RELEASE. jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable.java:86) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core。 publisher.Flux.subscribe(Flux.java:8325) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxFlatMap$FlatMapMain.onNext(FluxFlatMap.java:418 ) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable$IterableSubscription.slowPath(FluxIterable.java:267) ~[reactor-core-3.3.6.发布.jar:3.3.6。RELEASE] 在 reactor.core.publisher.FluxIterable$IterableSubscription.request(FluxIterable.java:225) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxFlatMap$ FlatMapMain.onSubscribe(FluxFlatMap.java:363) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable.java:161) ~[reactor -core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable.java:86) ~[reactor-core-3.3.6.RELEASE.jar:3.3. 6.RELEASE] 在 reactor.core.publisher.Flux.subscribe(Flux.java:8325) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxFlatMap$ FlatMapMain.onNext(FluxFlatMap.java:418) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable$IterableSubscription.slowPath(FluxIterable.java:267)~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE]在reactor.core.publisher.FluxIterable$IterableSubscription.request(FluxIterable.java:225)~[reactor-core-3.3.6 .RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxFlatMap$FlatMapMain.onSubscribe(FluxFlatMap.java:363) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE]在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable.java:161) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxIterable.subscribe(FluxIterable. java:86) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.InternalFluxOperator.subscribe(InternalFluxOperator.java:62) ~[reactor-core-3.3.6 .RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.FluxDefer.subscribe(FluxDefer.java:54) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor .core.publisher.Flux。订阅(Flux.java:8325)~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] at reactor.core.publisher.Flux.subscribeWith(Flux.java:8494)~[reactor-core -3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.Flux.subscribe(Flux.java:8295) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6. RELEASE] 在 reactor.core.publisher.Flux.subscribe(Flux.java:8222) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] 在 reactor.core.publisher.Flux.subscribe( Flux.java:8140) ~[reactor-core-3.3.6.RELEASE.jar:3.3.6.RELEASE] at org.springframework.cloud.gateway.filter.WeightCalculatorWebFilter.lambda$onApplicationEvent$0(WeightCalculatorWebFilter.java:145) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE] at org.springframework.beans.factory.ObjectProvider.ifAvailable(ObjectProvider.java:93) ~[spring-beans-5.2 .7.RELEASE.jar:5.2.7.RELEASE] 在 org.springframework.cloud.gateway.filter.WeightCalculatorWebFilter.onApplicationEvent(WeightCalculatorWebFilter.java:145) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE] at org.springframework.context.event .SimpleApplicationEventMulticaster.doInvokeListener(SimpleApplicationEventMulticaster.java:172) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.context.event.SimpleApplicationEventMulticaster.invokeListener(SimpleApplicationEventMulticaster.java:165) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:139) ~[spring-context-5.2.7.RELEASE .jar:5.2.7.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:404)~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:361)~[spring-context-5.2.7 .RELEASE.jar:5.2.7.RELEASE] 在 org.springframework.cloud.gateway.route.RouteRefreshListener.reset(RouteRefreshListener.java:68) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar: 2.2.0.RELEASE] 在 org.springframework.cloud.gateway.route.RouteRefreshListener.onApplicationEvent(RouteRefreshListener.java:49) ~[spring-cloud-gateway-core-2.2.0.RELEASE.jar:2.2.0.RELEASE ] 在 org.springframework.context.event.SimpleApplicationEventMulticaster.doInvokeListener(SimpleApplicationEventMulticaster.java:172) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] 在 org.springframework.context.event.SimpleApplicationEventMulticaster .invokeListener(SimpleApplicationEventMulticaster.java:165)~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.context.event.SimpleApplicationEventMulticaster.multicastEvent(SimpleApplicationEventMulticaster.java:139)~[spring -context-5.2.7.RELEASE.jar:5.2.7.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:404) ~[spring-context-5.2.7.RELEASE.jar: 5.2.7.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.publishEvent(AbstractApplicationContext.java:361) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] 在 org.springframework。 context.support.AbstractApplicationContext.finishRefresh(AbstractApplicationContext.java:898) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.context.support。AbstractApplicationContext.refresh(AbstractApplicationContext.java:554) ~[spring-context-5.2.7.RELEASE.jar:5.2.7.RELEASE] at org.springframework.boot.web.reactive.context.ReactiveWebServerApplicationContext.refresh(ReactiveWebServerApplicationContext.java :62) ~[spring-boot-2.3.1.RELEASE.jar:2.3.1.RELEASE] at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:758) [spring-boot-2.3.1.RELEASE .jar:2.3.1.RELEASE] 在 org.springframework.boot.SpringApplication.refresh(SpringApplication.java:750) [spring-boot-2.3.1.RELEASE.jar:2.3.1.RELEASE] 在 org.springframework。 boot.SpringApplication.refreshContext(SpringApplication.java:397) [spring-boot-2.3.1.RELEASE.jar:2.3.1.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:315) [spring -boot-2.3.1.RELEASE.jar:2.3.1.RELEASE] 在 org.springframework.boot.SpringApplication.run(SpringApplication.java:1237) [spring-boot-2.3.1.RELEASE.jar:2.3.1.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1226) [spring-boot-2.3.1.RELEASE.jar:2.3.1.RELEASE]
自定义过滤器名称.java
@Component
public class CustomFilterName extends AbstractGatewayFilterFactory<CustomFilterName.Config> {
final Logger logger = LoggerFactory.getLogger(CustomFilterName.class);
public static final String A_var = "thisIsA_Class";
public static final String B_var = "thisIsB_Class";
public CustomFilterName() {
super(Config.class);
}
@Override
public GatewayFilter apply(Config config) {
return new OrderedGatewayFilter((exchange, chain) -> {
logger.info("Pre GatewayFilter logging: " + config.getA_var());
return chain.filter(exchange).then(Mono.fromRunnable(() -> {
logger.info("Post GatewayFilter logging: " + config.getB_var());
}));
}, 1);
}
public static class Config {
private String A_var;
private String B_var;
public String getA_var() {
return A_var;
}
public void setA_var(String a_var) {
A_var = a_var;
}
public String getB_var() {
return B_var;
}
public void setB_var(String b_var) {
B_var = b_var;
}
public Config() {
};
public Config(String A_var, String B_var) {
super();
this.A_var = A_var;
this.B_var = B_var;
}
}
}
应用程序.yml
spring:
application:
name: gs-gateway
cloud:
gateway:
routes:
- id: test_route
uri: http://httpbin.org/
predicates:
- Path=/incoming/**
filters:
- AddRequestHeader=X-Y-Host, delta
- name: CustomFilterName
args:
A_var: thisIsA_yml
B_var: thisIsB_yml
pom.xml
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.1.RELEASE</version>
<relativePath /> <!-- lookup parent from repository -->
</parent>
<spring-cloud.version>Hoxton.RELEASE</spring-cloud.version>
<spring-cloud-gateway.version>2.2.1.RELEASE</spring-cloud-gateway.version>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-gateway</artifactId>
<version>${spring-cloud-gateway.version}</version>
</dependency>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
解决方案
是的,我必须通过删除 repo 文件夹中的所有旧依赖项来清理我的 M2 repo 文件夹。并进行了新的 Maven Force Update。上面提到的错误消失了。
推荐阅读
- python - Python设置属性等于另一个属性
- angular - 量角器超时角度 6
- data-science - 我们能得到原始的谷歌广告词数据吗?
- jira - Apache Ignite JIRA - 删除问题
- java - JAVA是什么导致网络套接字上的流结束?
- symfony - Akeneo 2.2.8:如何在 akeneo.storage.pre_save 事件中获取原始属性数据?
- android - 如何在对话框警报按钮中使用媒体播放器
- batch-file - 如何在多个txt文件中用单个空格替换多个空格?
- .htaccess - url 上的 RedirectMatch 不包含任何参数?
- azure - Azure IoT Edge Store and Forward Live Over Power Cycles