Skip to content

Commit

Permalink
Merge branch '2.3.x' into 2.4.x
Browse files Browse the repository at this point in the history
Closes gh-25064
  • Loading branch information
philwebb committed Jan 31, 2021
2 parents d7c44e4 + 19c5864 commit 9ac5151
Showing 1 changed file with 12 additions and 7 deletions.
Expand Up @@ -1489,9 +1489,10 @@ TIP: We recommend that, when possible, properties are stored in lower-case kebab

[[boot-features-external-config-relaxed-binding-maps]]
===== Binding Maps
When binding to `Map` properties, if the `key` contains anything other than lowercase alpha-numeric characters or `-`, you need to use the bracket notation so that the original value is preserved.
If the key is not surrounded by `[]`, any characters that are not alpha-numeric or `-` are removed.
For example, consider binding the following properties to a `Map`:
When binding to `Map` properties you may need to use a special bracket notation so that the original `key` value is preserved.
If the key is not surrounded by `[]`, any characters that are not alpha-numeric, `-` or `.` are removed.

For example, consider binding the following properties to a `Map<String,String>`:


[source,properties,indent=0,role="primary"]
Expand All @@ -1507,14 +1508,18 @@ For example, consider binding the following properties to a `Map`:
----
acme:
map:
"[/key1]": value1
"[/key2]": value2
"/key3": value3
"[/key1]": "value1"
"[/key2]": "value2"
"/key3": "value3"
----

NOTE: For YAML files, the brackets need to be surrounded by quotes for the keys to be parsed properly.

The properties above will bind to a `Map` with `/key1`, `/key2` and `key3` as the keys in the map.
The slash has been removed from `key3` because it wasn't surrounded by square brackets.

NOTE: For YAML files, the brackets need to be surrounded by quotes for the keys to be parsed properly.
You may also occasionally need to use the bracket notation if your `key` contains a `.` and you are binding to non-scalar value.
For example, binding `a.b=c` to `Map<String, Object>` will return a Map with the entry `{"a"={"b"="c"}}` where as `[a.b]=c` will return a Map with the entry `{"a.b"="c"}`.



Expand Down

0 comments on commit 9ac5151

Please sign in to comment.