public class UriTemplate
extends java.lang.Object
implements java.io.Serializable
{, }), which can be expanded to produce an actual URI.
See expand(Map), expand(Object[]), and match(String) for example usages.
| Constructor and Description |
|---|
UriTemplate(java.lang.String uriTemplate)
Construct a new
UriTemplate with the given URI String. |
| Modifier and Type | Method and Description |
|---|---|
protected java.net.URI |
encodeUri(java.lang.String uri)
Deprecated.
No longer in use, with no direct replacement
|
java.net.URI |
expand(java.util.Map<java.lang.String,?> uriVariables)
Given the Map of variables, expands this template into a URI.
|
java.net.URI |
expand(java.lang.Object... uriVariableValues)
Given an array of variables, expand this template into a full URI.
|
java.util.List<java.lang.String> |
getVariableNames()
Return the names of the variables in the template, in order.
|
java.util.Map<java.lang.String,java.lang.String> |
match(java.lang.String uri)
Match the given URI to a map of variable values.
|
boolean |
matches(java.lang.String uri)
Indicate whether the given URI matches this template.
|
java.lang.String |
toString() |
public UriTemplate(java.lang.String uriTemplate)
UriTemplate with the given URI String.uriTemplate - the URI template stringpublic java.util.List<java.lang.String> getVariableNames()
public java.net.URI expand(java.util.Map<java.lang.String,?> uriVariables)
Example:
UriTemplate template = new UriTemplate("http://example.com/hotels/{hotel}/bookings/{booking}");
Map<String, String> uriVariables = new HashMap<String, String>();
uriVariables.put("booking", "42");
uriVariables.put("hotel", "1");
System.out.println(template.expand(uriVariables));
will print: http://example.com/hotels/1/bookings/42uriVariables - the map of URI variablesjava.lang.IllegalArgumentException - if uriVariables is null;
or if it does not contain values for all the variable namespublic java.net.URI expand(java.lang.Object... uriVariableValues)
Example:
UriTemplate template = new UriTemplate("http://example.com/hotels/{hotel}/bookings/{booking}");
System.out.println(template.expand("1", "42));
will print: http://example.com/hotels/1/bookings/42uriVariableValues - the array of URI variablesjava.lang.IllegalArgumentException - if uriVariables is null
or if it does not contain sufficient variablespublic boolean matches(java.lang.String uri)
uri - the URI to match totrue if it matches; false otherwisepublic java.util.Map<java.lang.String,java.lang.String> match(java.lang.String uri)
Example:
UriTemplate template = new UriTemplate("http://example.com/hotels/{hotel}/bookings/{booking}");
System.out.println(template.match("http://example.com/hotels/1/bookings/42"));
will print: {hotel=1, booking=42}uri - the URI to match to@Deprecated protected java.net.URI encodeUri(java.lang.String uri)
Defaults to UriUtils.encodeUri(String, String).
uri - the URI to encodepublic java.lang.String toString()
toString in class java.lang.Object