public abstract class PlaceholderConfigurerSupport extends PropertyResourceConfigurer implements BeanNameAware, BeanFactoryAware
The default placeholder syntax follows the Ant / Log4J / JSP EL style:
${...}
Example XML bean definition:
Example properties file:
driver=com.mysql.jdbc.Driver dbname=mysql:mydbAnnotated bean definitions may take advantage of property replacement using the
@Value annotation:
@Value("${person.age}")
Implementations check simple property values, lists, maps, props, and bean names
in bean references. Furthermore, placeholder values can also cross-reference
other placeholders, like:
rootPath=myrootdir
subPath=${rootPath}/subdir
In contrast to PropertyOverrideConfigurer, subclasses of this type allow
filling in of explicit placeholders in bean definitions.
If a configurer cannot resolve a placeholder, a BeanDefinitionStoreException
will be thrown. If you want to check against multiple properties files, specify multiple
resources via the locations property. You can also define multiple
configurers, each with its own placeholder syntax. Use ignoreUnresolvablePlaceholders to intentionally suppress throwing an exception if a
placeholder cannot be resolved.
Default property values can be defined globally for each configurer instance
via the properties property, or on a property-by-property basis
using the default value separator which is ":" by default and
customizable via setValueSeparator(String).
Example XML property with default value:
PropertyPlaceholderConfigurer,
org.springframework.context.support.PropertySourcesPlaceholderConfigurer| Modifier and Type | Field and Description |
|---|---|
static String |
DEFAULT_PLACEHOLDER_PREFIX
Default placeholder prefix: "${"
|
static String |
DEFAULT_PLACEHOLDER_SUFFIX
Default placeholder suffix: "}"
|
static String |
DEFAULT_VALUE_SEPARATOR
Default value separator: ":"
|
protected boolean |
ignoreUnresolvablePlaceholders |
protected String |
nullValue |
protected String |
placeholderPrefix
Defaults to "${"
|
protected String |
placeholderSuffix
Defaults to "}"
|
protected boolean |
trimValues |
protected String |
valueSeparator
Defaults to ":"
|
| Constructor and Description |
|---|
PlaceholderConfigurerSupport() |
| Modifier and Type | Method and Description |
|---|---|
protected void |
doProcessProperties(ConfigurableListableBeanFactory beanFactoryToProcess,
org.springframework.util.StringValueResolver valueResolver) |
void |
setBeanFactory(BeanFactory beanFactory)
Only necessary to check that we're not parsing our own bean definition,
to avoid failing on unresolvable placeholders in properties file locations.
|
void |
setBeanName(String beanName)
Only necessary to check that we're not parsing our own bean definition,
to avoid failing on unresolvable placeholders in properties file locations.
|
void |
setIgnoreUnresolvablePlaceholders(boolean ignoreUnresolvablePlaceholders)
Set whether to ignore unresolvable placeholders.
|
void |
setNullValue(String nullValue)
Set a value that should be treated as
null when resolved
as a placeholder value: e.g. |
void |
setPlaceholderPrefix(String placeholderPrefix)
Set the prefix that a placeholder string starts with.
|
void |
setPlaceholderSuffix(String placeholderSuffix)
Set the suffix that a placeholder string ends with.
|
void |
setTrimValues(boolean trimValues)
Specify whether to trim resolved values before applying them,
removing superfluous whitespace from the beginning and end.
|
void |
setValueSeparator(String valueSeparator)
Specify the separating character between the placeholder variable
and the associated default value, or
null if no such
special character should be processed as a value separator. |
convertProperties, convertProperty, convertPropertyValue, getOrder, postProcessBeanFactory, processProperties, setOrderpublic static final String DEFAULT_PLACEHOLDER_PREFIX
public static final String DEFAULT_PLACEHOLDER_SUFFIX
public static final String DEFAULT_VALUE_SEPARATOR
protected boolean trimValues
protected String nullValue
protected boolean ignoreUnresolvablePlaceholders
public void setPlaceholderPrefix(String placeholderPrefix)
public void setPlaceholderSuffix(String placeholderSuffix)
public void setValueSeparator(String valueSeparator)
null if no such
special character should be processed as a value separator.
The default is ":".public void setTrimValues(boolean trimValues)
Default is false.
public void setNullValue(String nullValue)
null when resolved
as a placeholder value: e.g. "" (empty String) or "null".
Note that this will only apply to full property values, not to parts of concatenated values.
By default, no such null value is defined. This means that
there is no way to express null as a property value
unless you explicitly map a corresponding value here.
public void setIgnoreUnresolvablePlaceholders(boolean ignoreUnresolvablePlaceholders)
Default is "false": An exception will be thrown if a placeholder fails to resolve. Switch this flag to "true" in order to preserve the placeholder String as-is in such a case, leaving it up to other placeholder configurers to resolve it.
public void setBeanName(String beanName)
setBeanName in interface BeanNameAwarebeanName - the name of the bean in the factory.
Note that this name is the actual bean name used in the factory, which may
differ from the originally specified name: in particular for inner bean
names, the actual bean name might have been made unique through appending
"#..." suffixes. Use the BeanFactoryUtils.originalBeanName(String)
method to extract the original bean name (without suffix), if desired.PropertiesLoaderSupport.setLocations(org.springframework.core.io.Resource...),
ResourceEditorpublic void setBeanFactory(BeanFactory beanFactory)
setBeanFactory in interface BeanFactoryAwarebeanFactory - owning BeanFactory (never null).
The bean can immediately call methods on the factory.PropertiesLoaderSupport.setLocations(org.springframework.core.io.Resource...),
ResourceEditorprotected void doProcessProperties(ConfigurableListableBeanFactory beanFactoryToProcess, org.springframework.util.StringValueResolver valueResolver)