支持通过Spring Cloud Gateway代理SOAP / XML端点

时间:2019-02-20 12:33:40

标签: spring-webflow project-reactor spring-cloud-gateway

尝试使用Spring Cloud Gateway代理肥皂服务时记录请求和响应。下面是代码段...引发IllegalStateException。

  

java.lang.IllegalStateException:仅一个连接接收   允许订阅者。在   react.netty.channel.FluxReceive.startReceiver(FluxReceive.java:271)   [reactor-netty-0.8.4.RELEASE.jar:0.8.4.RELEASE]位于   react.netty.channel.FluxReceive.subscribe(FluxReceive.java:121)   [reactor-netty-0.8.4.RELEASE.jar:0.8.4.RELEASE]

--- Spring Versions ---

SpringBoot                  : 2.1.2.RELEASE
spring-cloud-gateway        : 2.1.1.BUILD-SNAPSHOT
spring-boot-starter-webflux : 2.1.2.RELEASE
reactor-core                : 3.2.5.RELEASE

GatewaySampleApplication

public class  GatewaySampleApplication {
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes() 
.route(
r ->
r.path("/security/getToken")
.filters( f -> f.preserveHostHeader()
.filter(new PolicyHandlerReactive()))
.uri("http://targetendpoint.xyz.com")
)
.build();
}
}

PolicyHandlerReactive:

PolicyHandlerReactive implements GatewayFilter  {

@Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) 
    {
        ServerHttpRequest request = (ServerHttpRequest) exchange.getRequest();
                Flux<DataBuffer> xmlReqFlux = request.getBody();    
                Mono<List<DataBuffer>> monoDataList = xmlReqFlux.collectList();
                monoDataList.map(dataA -> logRequest2(dataA)).subscribe();
        return chain.filter(exchange);
        }
}
private List<DataBuffer> logRequest(List<DataBuffer> dataA) {           

    ListIterator<DataBuffer> dataAList = dataA.listIterator();

    while(dataAList.hasNext() ) {
        DataBuffer dataBuffer = dataAList.next();
        InputStream is = dataBuffer.asInputStream();
        System.out.println(convertStreamToString(is));
    }       
    return dataA;
}   

1 个答案:

答案 0 :(得分:0)

可以使用.modifyRequestBody而不是过滤器来解决此问题... 下面更新了Java DSL ...

    .route(
                    r ->
                    r.path("external/v2/security/")
                    .filters( f -> f
                            .preserveHostHeader()
                            .modifyRequestBody(String.class, String.class, 
                            (exchange, s) -> {
                                Mono<String> dataA = Mono.just(s); 
                                dataA.subscribe(System.out::print); 
                                return dataA; 
                            })                              
                         )                                                                                               
                    .uri("http://targetendpoint.xyz.com")
                    )
相关问题