public abstract class RouterFunctions extends Object
RouterFunction
using a discoverable builder-style API, to
create a RouterFunction
given a RequestPredicate
and HandlerFunction
, and to do further
subrouting on an existing routing
function.Modifier and Type | Class and Description |
---|---|
static interface |
RouterFunctions.Builder
Represents a discoverable builder for router functions.
|
static interface |
RouterFunctions.Visitor
Receives notifications from the logical structure of router functions.
|
Modifier and Type | Field and Description |
---|---|
static String |
MATCHING_PATTERN_ATTRIBUTE
Name of the request attribute that contains the matching pattern, as a
PathPattern . |
static String |
REQUEST_ATTRIBUTE
Name of the request attribute that contains the
ServerRequest . |
static String |
URI_TEMPLATE_VARIABLES_ATTRIBUTE
Name of the request attribute that contains the URI
templates map, mapping variable names to values.
|
Constructor and Description |
---|
RouterFunctions() |
Modifier and Type | Method and Description |
---|---|
static <T extends ServerResponse> |
changeParser(RouterFunction<T> routerFunction,
PathPatternParser parser)
Changes the
PathPatternParser on the given router function. |
static <T extends ServerResponse> |
nest(RequestPredicate predicate,
RouterFunction<T> routerFunction)
Route to the given router function if the given request predicate applies.
|
static Function<ServerRequest,Optional<Resource>> |
resourceLookupFunction(String pattern,
Resource location)
Returns the resource lookup function used by
resources(String, Resource) . |
static RouterFunction<ServerResponse> |
resources(Function<ServerRequest,Optional<Resource>> lookupFunction)
Route to resources using the provided lookup function.
|
static RouterFunction<ServerResponse> |
resources(String pattern,
Resource location)
Route requests that match the given pattern to resources relative to the given root location.
|
static RouterFunctions.Builder |
route()
Offers a discoverable way to create router functions through a builder-style interface.
|
static <T extends ServerResponse> |
route(RequestPredicate predicate,
HandlerFunction<T> handlerFunction)
Route to the given handler function if the given request predicate applies.
|
public static final String REQUEST_ATTRIBUTE
ServerRequest
.public static final String URI_TEMPLATE_VARIABLES_ATTRIBUTE
public static final String MATCHING_PATTERN_ATTRIBUTE
PathPattern
.public static RouterFunctions.Builder route()
public static <T extends ServerResponse> RouterFunction<T> route(RequestPredicate predicate, HandlerFunction<T> handlerFunction)
For instance, the following example routes GET requests for "/user" to the
listUsers
method in userController
:
RouterFunction<ServerResponse> route = RouterFunctions.route(RequestPredicates.GET("/user"), userController::listUsers);
T
- the type of response returned by the handler functionpredicate
- the predicate to testhandlerFunction
- the handler function to route to if the predicate applieshandlerFunction
if
predicate
evaluates to true
RequestPredicates
public static <T extends ServerResponse> RouterFunction<T> nest(RequestPredicate predicate, RouterFunction<T> routerFunction)
For instance, the following example first creates a composed route that resolves to
listUsers
for a GET, and createUser
for a POST. This composed route then gets
nested with a "/user" path predicate, so that GET requests for "/user" will list users,
and POST request for "/user" will create a new user.
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
- the type of response returned by the handler functionpredicate
- the predicate to testrouterFunction
- the nested router function to delegate to if the predicate appliesrouterFunction
if
predicate
evaluates to true
RequestPredicates
public static RouterFunction<ServerResponse> resources(String pattern, Resource location)
Resource location = new FileSystemResource("public-resources/"); RouterFunction<ServerResponse> resources = RouterFunctions.resources("/resources/**", location);
pattern
- the pattern to matchlocation
- the location directory relative to which resources should be resolvedresourceLookupFunction(String, Resource)
public static Function<ServerRequest,Optional<Resource>> resourceLookupFunction(String pattern, Resource location)
resources(String, Resource)
.
The returned function can be composed on, for
instance to return a default resource when the lookup function does not match:
Optional<Resource> defaultResource = Optional.of(new ClassPathResource("index.html")); Function<ServerRequest, Optional<Resource>> lookupFunction = RouterFunctions.resourceLookupFunction("/resources/**", new FileSystemResource("public-resources/")) .andThen(resource -> resource.or(() -> defaultResource)); RouterFunction<ServerResponse> resources = RouterFunctions.resources(lookupFunction);
pattern
- the pattern to matchlocation
- the location directory relative to which resources should be resolvedpublic static RouterFunction<ServerResponse> resources(Function<ServerRequest,Optional<Resource>> lookupFunction)
Resource
for the given request, it will be it will be exposed using a
HandlerFunction
that handles GET, HEAD, and OPTIONS requests.lookupFunction
- the function to provide a Resource
given the ServerRequest
public static <T extends ServerResponse> RouterFunction<T> changeParser(RouterFunction<T> routerFunction, PathPatternParser parser)
PathPatternParser
on the given router function. This method
can be used to change the PathPatternParser
properties from the defaults, for instance to change
case sensitivity.T
- the type of response returned by the handler functionrouterFunction
- the router function to change the parser inparser
- the parser to change to.