クラス RouterFunctions
java.lang.ObjectSE
org.springframework.web.reactive.function.server.RouterFunctions
Spring の関数 Web フレームワークへの主要エントリポイント。発見可能なビルダースタイルの API を使用して
RouterFunction
を作成したり、RequestPredicate
および HandlerFunction
を指定して RouterFunction
を作成したり、既存のルーティング関数でさらにサブルーチン化したりするなど、ルーティング機能を公開します。 さらに、このクラスは RouterFunction
を HttpHandler
に変換でき、サーブレット環境、Reactor、Undertow で実行できます。
- 導入:
- 5.0
- 作成者:
- Arjen Poutsma, Sebastien Deleuze
ネストされたクラスのサマリー
修飾子と型クラス説明static interface
ルーター関数の検出可能なビルダーを表します。static interface
ルーター関数の論理構造から通知を受け取ります。フィールドサマリー
修飾子と型フィールド説明static final StringSE
一致するパターンを含むattribute
の名前 (PathPattern
として)。static final StringSE
ServerRequest
を含むServerWebExchange
属性の名前。static final StringSE
URI テンプレートマップを含むServerWebExchange
属性の名前。変数名を値にマッピングします。コンストラクターのサマリー
メソッドのサマリー
修飾子と型メソッド説明static <T extends ServerResponse>
RouterFunction<T>changeParser
(RouterFunction<T> routerFunction, PathPatternParser parser) 指定されたルーター関数のPathPatternParser
を変更します。static <T extends ServerResponse>
RouterFunction<T>nest
(RequestPredicate predicate, RouterFunction<T> routerFunction) 指定されたリクエスト述語が適用される場合、指定されたルーター関数にルーティングします。static RouterFunction<ServerResponse>
resource
(RequestPredicate predicate, Resource resource) 指定された述語に一致するリクエストを指定されたリソースにルーティングします。static RouterFunction<ServerResponse>
resource
(RequestPredicate predicate, Resource resource, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 指定された述語に一致するリクエストを指定されたリソースにルーティングします。static FunctionSE<ServerRequest,
reactor.core.publisher.Mono<Resource>> resourceLookupFunction
(StringSE pattern, Resource location) resources(String, Resource)
で使用されるリソース検索関数を返します。static RouterFunction<ServerResponse>
指定されたパターンに一致するリクエストを、指定されたルートの場所を基準としたリソースにルーティングします。static RouterFunction<ServerResponse>
resources
(StringSE pattern, Resource location, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 指定されたパターンに一致するリクエストを、指定されたルートの場所を基準としたリソースにルーティングします。static RouterFunction<ServerResponse>
resources
(FunctionSE<ServerRequest, reactor.core.publisher.Mono<Resource>> lookupFunction) 提供された検索機能を使用してリソースにルーティングします。static RouterFunction<ServerResponse>
resources
(FunctionSE<ServerRequest, reactor.core.publisher.Mono<Resource>> lookupFunction, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 提供された検索機能を使用してリソースにルーティングします。static RouterFunctions.Builder
route()
ビルダースタイルのインターフェースを介してルーター関数を作成する発見可能な方法を提供します。static <T extends ServerResponse>
RouterFunction<T>route
(RequestPredicate predicate, HandlerFunction<T> handlerFunction) 指定されたリクエスト述語が適用される場合、指定されたハンドラー関数にルーティングします。static HttpHandler
toHttpHandler
(RouterFunction<?> routerFunction) static HttpHandler
toHttpHandler
(RouterFunction<?> routerFunction, HandlerStrategies strategies) 指定された戦略を使用して、指定されたルーター関数をHttpHandler
に変換します。static WebHandler
toWebHandler
(RouterFunction<?> routerFunction) 指定されたルーター関数をWebHandler
に変換します。static WebHandler
toWebHandler
(RouterFunction<?> routerFunction, HandlerStrategies strategies) 指定された戦略を使用して、指定されたルーター関数をWebHandler
に変換します。
フィールドの詳細
REQUEST_ATTRIBUTE
ServerRequest
を含むServerWebExchange
属性の名前。URI_TEMPLATE_VARIABLES_ATTRIBUTE
URI テンプレートマップを含むServerWebExchange
属性の名前。変数名を値にマッピングします。MATCHING_PATTERN_ATTRIBUTE
一致するパターンを含むattribute
の名前 (PathPattern
として)。
コンストラクターの詳細
RouterFunctions
public RouterFunctions()
メソッドの詳細
route
ビルダースタイルのインターフェースを介してルーター関数を作成する発見可能な方法を提供します。- 戻り値:
- ルーター関数ビルダー
- 導入:
- 5.1
route
public static <T extends ServerResponse> RouterFunction<T> route(RequestPredicate predicate, HandlerFunction<T> handlerFunction) 指定されたリクエスト述語が適用される場合、指定されたハンドラー関数にルーティングします。たとえば、次の例では、"/user" の GET リクエストを
userController
のlistUsers
メソッドにルーティングします。RouterFunction<ServerResponse> route = RouterFunctions.route(RequestPredicates.GET("/user"), userController::listUsers);
- 型パラメーター:
T
- ハンドラー関数によって返されるレスポンスの型- パラメーター:
predicate
- テストする述語handlerFunction
- 述語が適用される場合にルーティングするハンドラー関数- 戻り値:
predicate
がtrue
と評価された場合にhandlerFunction
にルーティングするルーター関数- 関連事項:
nest
public static <T extends ServerResponse> RouterFunction<T> nest(RequestPredicate predicate, RouterFunction<T> routerFunction) 指定されたリクエスト述語が適用される場合、指定されたルーター関数にルーティングします。このメソッドを使用して、ネストされたルートを作成できます。ルートのグループは、共通のパス(プレフィックス)、ヘッダー、その他のリクエスト述語を共有します。たとえば、次の例では、最初に、GET の場合は
listUsers
に、POST の場合はcreateUser
に解決される合成ルートを作成します。次に、この構成されたルートは "/user" パス述語でネストされるため、"/user" の GET リクエストはユーザーをリストし、"/user" の POST リクエストは新しいユーザーを作成します。RouterFunction<ServerResponse> userRoutes = RouterFunctions.route(RequestPredicates.method(HttpMethod.GET), this::listUsers) .andRoute(RequestPredicates.method(HttpMethod.POST), this::createUser); RouterFunction<ServerResponse> nestedRoute = RouterFunctions.nest(RequestPredicates.path("/user"), userRoutes);
- 型パラメーター:
T
- ハンドラー関数によって返されるレスポンスの型- パラメーター:
predicate
- テストする述語routerFunction
- 述語が適用される場合に委譲するネストされたルーター関数- 戻り値:
predicate
がtrue
と評価された場合にrouterFunction
にルーティングするルーター関数- 関連事項:
resource
public static RouterFunction<ServerResponse> resource(RequestPredicate predicate, Resource resource) 指定された述語に一致するリクエストを指定されたリソースにルーティングします。たとえばResource resource = new ClassPathResource("static/index.html") RouterFunction<ServerResponse> resources = RouterFunctions.resource(path("/api/**").negate(), resource);
- パラメーター:
predicate
- 一致する述語resource
- 提供するリソース- 戻り値:
- リソースにルーティングするルーター関数
- 導入:
- 6.1.4
resource
public static RouterFunction<ServerResponse> resource(RequestPredicate predicate, Resource resource, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 指定された述語に一致するリクエストを指定されたリソースにルーティングします。たとえばResource resource = new ClassPathResource("static/index.html") RouterFunction<ServerResponse> resources = RouterFunctions.resource(path("/api/**").negate(), resource);
- パラメーター:
predicate
- 一致する述語resource
- 提供するリソースheadersConsumer
- 提供されるリソースの HTTP ヘッダーへのアクセスを提供します- 戻り値:
- リソースにルーティングするルーター関数
- 導入:
- 6.1.4
resources
指定されたパターンに一致するリクエストを、指定されたルートの場所を基準にしたリソースにルーティングします。たとえばResource location = new FileUrlResource("public-resources/"); RouterFunction<ServerResponse> resources = RouterFunctions.resources("/resources/**", location);
- パラメーター:
pattern
- マッチングするパターンlocation
- リソースを解決する必要のある場所のディレクトリ- 戻り値:
- リソースにルーティングするルーター関数
- 関連事項:
resources
public static RouterFunction<ServerResponse> resources(StringSE pattern, Resource location, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 指定されたパターンに一致するリクエストを、指定されたルートの場所を基準にしたリソースにルーティングします。たとえばResource location = new FileUrlResource("public-resources/"); RouterFunction<ServerResponse> resources = RouterFunctions.resources("/resources/**", location);
- パラメーター:
pattern
- マッチングするパターンlocation
- リソースを解決する必要のある場所のディレクトリheadersConsumer
- 提供されるリソースの HTTP ヘッダーへのアクセスを提供します- 戻り値:
- リソースにルーティングするルーター関数
- 導入:
- 6.1
- 関連事項:
resourceLookupFunction
public static FunctionSE<ServerRequest,reactor.core.publisher.Mono<Resource>> resourceLookupFunction(StringSE pattern, Resource location) resources(String, Resource)
で使用されるリソースルックアップ関数を返します。返される関数は、たとえば、ルックアップ関数が一致しない場合にデフォルトのリソースを返すように構成SEできます。Mono<Resource> defaultResource = Mono.just(new ClassPathResource("index.html")); Function<ServerRequest, Mono<Resource>> lookupFunction = RouterFunctions.resourceLookupFunction("/resources/**", new FileUrlResource("public-resources/")) .andThen(resourceMono -> resourceMono.switchIfEmpty(defaultResource)); RouterFunction<ServerResponse> resources = RouterFunctions.resources(lookupFunction);
- パラメーター:
pattern
- マッチングするパターンlocation
- リソースを解決する必要のある場所のディレクトリ- 戻り値:
- 指定されたパラメーターのデフォルトのリソース検索関数。
- 関連事項:
resources
public static RouterFunction<ServerResponse> resources(FunctionSE<ServerRequest, reactor.core.publisher.Mono<Resource>> lookupFunction) 提供された検索機能を使用してリソースにルーティングします。ルックアップ関数が指定されたリクエストにResource
を提供する場合、GET、HEAD、OPTIONS リクエストを処理するHandlerFunction
を使用して公開されます。- パラメーター:
lookupFunction
-ServerRequest
を指定してResource
を提供する関数- 戻り値:
- リソースにルーティングするルーター関数
resources
public static RouterFunction<ServerResponse> resources(FunctionSE<ServerRequest, reactor.core.publisher.Mono<Resource>> lookupFunction, BiConsumerSE<Resource, HttpHeaders> headersConsumer) 提供された検索機能を使用してリソースにルーティングします。ルックアップ関数が指定されたリクエストにResource
を提供する場合、GET、HEAD、OPTIONS リクエストを処理するHandlerFunction
を使用して公開されます。- パラメーター:
lookupFunction
-ServerRequest
を指定してResource
を提供する関数headersConsumer
- 提供されるリソースの HTTP ヘッダーへのアクセスを提供します- 戻り値:
- リソースにルーティングするルーター関数
- 導入:
- 6.1
toHttpHandler
デフォルトの戦略を使用して、指定されたルーター関数をHttpHandler
に変換します。返されたハンドラーは、次の環境で実行するように適応できます。
ServletHttpHandlerAdapter
を使用したサーブレット環境ReactorHttpHandlerAdapter
を使用した ReactorUndertowHttpHandlerAdapter
を使用した Undertow
HttpWebHandlerAdapter
はWebHandler
も実装しているため、WebHttpHandlerBuilder
を介して追加のフィルターと例外ハンドラーを登録できることに注意してください。- パラメーター:
routerFunction
- 変換するルーター関数- 戻り値:
- 指定されたルーター関数を使用して HTTP リクエストを処理する HTTP ハンドラー
toHttpHandler
public static HttpHandler toHttpHandler(RouterFunction<?> routerFunction, HandlerStrategies strategies) 指定された戦略を使用して、指定されたルーター関数をHttpHandler
に変換します。返されたハンドラーは、次の環境で実行するように適応できます。
ServletHttpHandlerAdapter
を使用したサーブレット環境ReactorHttpHandlerAdapter
を使用した ReactorUndertowHttpHandlerAdapter
を使用した Undertow
- パラメーター:
routerFunction
- 変換するルーター関数strategies
- 使用する戦略- 戻り値:
- 指定されたルーター関数を使用して HTTP リクエストを処理する HTTP ハンドラー
toWebHandler
- パラメーター:
routerFunction
- 変換するルーター関数- 戻り値:
- 指定されたルーター関数を使用して Web リクエストを処理する Web ハンドラー
toWebHandler
public static WebHandler toWebHandler(RouterFunction<?> routerFunction, HandlerStrategies strategies) 指定された戦略を使用して、指定されたルーター関数をWebHandler
に変換します。- パラメーター:
routerFunction
- 変換するルーター関数strategies
- 使用する戦略- 戻り値:
- 指定されたルーター関数を使用して Web リクエストを処理する Web ハンドラー
changeParser
public static <T extends ServerResponse> RouterFunction<T> changeParser(RouterFunction<T> routerFunction, PathPatternParser parser) 指定されたルーター関数のPathPatternParser
を変更します。このメソッドを使用すると、PathPatternParser
プロパティをデフォルトから変更することができます (たとえば、大文字と小文字の区別を変更するなど)。- 型パラメーター:
T
- ハンドラー関数によって返されるレスポンスの型- パラメーター:
routerFunction
- パーサーを変更するルーター関数parser
- 変更するパーサー。- 戻り値:
- ルーター変更機能