parameterList

Description

Extracts all parameters at once in the original order as (name, value) tuples of type Map.Entry<String, String>.

This directive can be used if the exact order of parameters is important or if parameters can occur several times.

See When to use which parameter directive? to understand when to use which directive.

Example

final Function<Entry, String> paramString =
  entry -> entry.getKey() + " = '" + entry.getValue() + "'";

final Route route = parameterList(params -> {
  final String pString = params.stream()
    .map(paramString::apply)
    .collect(Collectors.joining(", "));

  return complete("The parameters are " + pString);
});

// tests:
testRoute(route).run(HttpRequest.GET("/?color=blue&count=42"))
  .assertEntity("The parameters are color = 'blue', count = '42'");

testRoute(route).run(HttpRequest.GET("/?x=1&x=2"))
  .assertEntity("The parameters are x = '1', x = '2'");
The source code for this page can be found here.