Spring Web Flux(反应性)功能路线与Kotlin无法正常工作

时间:2017-03-02 11:10:29

标签: spring kotlin reactive-programming spring-webflux

您好有兴趣在Kotlin编写spring应用程序的人。我正在使用Spring Boot 2.0.0快照和spring-webflux。这段代码:

@Component
class TestRouter() : RouterFunction<ServerResponse> {
  override fun route(request: ServerRequest) = route(request) {
    "/".route {
      GET("/hello") { ServerResponse.ok().body(BodyInserters.fromObject("World")) }
      "/{id}".route {
        GET("/hello") { ServerResponse.ok().body(BodyInserters.fromObject("World ${request.pathVariable("id")}")) }
      }
    }
  }
}

无法按预期工作(至少如我所料:))

➜  ~ curl -i http://localhost:8080/hello
HTTP/1.1 200 OK
transfer-encoding: chunked
Content-Type: text/plain;charset=UTF-8

World

但:

➜  ~ curl -i http://localhost:8080/1/hello
HTTP/1.1 404 Not Found
content-length: 0

工作案例追踪:

2017-03-03 00:58:03.865 TRACE 7666 --- [ctor-http-nio-4] o.s.w.r.f.server.RequestPredicates       : Pattern "//**" matches against value "/hello"
2017-03-03 00:58:03.865 DEBUG 7666 --- [ctor-http-nio-4] o.s.w.r.function.server.RouterFunctions  : Nested predicate "//**" matches against "GET /hello"
2017-03-03 00:58:03.865 TRACE 7666 --- [ctor-http-nio-4] o.s.w.r.f.server.RequestPredicates       : Method "GET" matches against value "GET"
2017-03-03 00:58:03.866 TRACE 7666 --- [ctor-http-nio-4] o.s.w.r.f.server.RequestPredicates       : Pattern "/hello" matches against value "/hello"
2017-03-03 00:58:03.866 DEBUG 7666 --- [ctor-http-nio-4] o.s.w.r.function.server.RouterFunctions  : Predicate "(GET && /hello)" matches against "GET /hello"

不是工作案例追踪:

2017-03-03 00:59:26.958 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Pattern "//**" matches against value "/1/hello"
2017-03-03 00:59:26.958 DEBUG 7666 --- [ctor-http-nio-1] o.s.w.r.function.server.RouterFunctions  : Nested predicate "//**" matches against "GET /1/hello"
2017-03-03 00:59:26.958 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Method "GET" matches against value "GET"
2017-03-03 00:59:26.958 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Pattern "/hello" does not match against value "/1/hello"
2017-03-03 00:59:26.959 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Pattern "/{id}/**" matches against value "/1/hello"
2017-03-03 00:59:26.959 DEBUG 7666 --- [ctor-http-nio-1] o.s.w.r.function.server.RouterFunctions  : Nested predicate "/{id}/**" matches against "GET /1/hello"
2017-03-03 00:59:26.959 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Method "GET" matches against value "GET"
2017-03-03 00:59:26.959 TRACE 7666 --- [ctor-http-nio-1] o.s.w.r.f.server.RequestPredicates       : Pattern "/hello" does not match against value "/1/hello"

这似乎是一个错误(因为"/{id}".route {...}据说使用RouterFunctions.nest),但我可能错了。欢迎您的想法和帮助。

我显然知道我可以通过编写/1/hello来使GET("/{id}/hello") { ... }工作,但我对嵌套的.route { ...}变体感兴趣,因为它支持我从另一个添加嵌套路由的用例位置(如地图等)。

1 个答案:

答案 0 :(得分:0)

此问题已在SPR-15310中修复。