|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.context.support.AbstractMessageSource org.springframework.context.support.ReloadableResourceBundleMessageSource
MessageSource that accesses the ResourceBundles with the specified basenames.
This class uses java.util.Properties
instances as its internal
data structure for messages, loading them via a PropertiesPersister strategy:
The default strategy can load properties files with a specific encoding.
In contrast to ResourceBundleMessageSource, this class supports reloading of properties files through the "cacheSeconds" setting, and also through programmatically clearing the properties cache. Since application servers do typically cache all files loaded from the classpath, it is necessary to store resources somewhere else (for example, in the "WEB-INF" directory of a web app). Otherwise changes of files in the classpath are not reflected in the application.
Note that the base names set as the "basename" and "basenames" properties are treated in a slightly different fashion than the "basename" property of ResourceBundleMessageSource. It follows the basic ResourceBundle rule of not specifying file extension or language codes, but can refer to any Spring resource location (instead of being restricted to classpath resources). With a "classpath:" prefix, resources can still be loaded from the classpath, but "cacheSeconds" values other than "-1" (caching forever) will not work in this case.
This MessageSource implementation is usually slightly faster than
ResourceBundleMessageSource, which builds on java.util.ResourceBundle
- in the default mode, i.e. when caching forever. With "cacheSeconds" set to 1,
message lookup takes about twice as long - with the benefit that changes in
individual properties files are detected with a maximum delay of 1 second.
Higher "cacheSeconds" values usually don't make a significant difference.
This MessageSource can easily be used outside an ApplicationContext: It uses a DefaultResourceLoader as default, getting overridden with the ApplicationContext if running in a context. It does not have any other specific dependencies.
Thanks to Thomas Achleitner for providing the initial implementation of this message source!
setCacheSeconds(int)
,
setBasenames(java.lang.String[])
,
setDefaultEncoding(java.lang.String)
,
setFileEncodings(java.util.Properties)
,
setPropertiesPersister(org.springframework.util.PropertiesPersister)
,
setResourceLoader(org.springframework.core.io.ResourceLoader)
,
DefaultPropertiesPersister
,
DefaultResourceLoader
,
ResourceBundleMessageSource
,
ResourceBundle
Nested Class Summary | |
protected class |
ReloadableResourceBundleMessageSource.PropertiesHolder
PropertiesHolder for caching. |
Field Summary |
Fields inherited from class org.springframework.context.support.AbstractMessageSource |
logger |
Constructor Summary | |
ReloadableResourceBundleMessageSource()
|
Method Summary | |
protected List |
calculateAllFilenames(String basename,
Locale locale)
Calculate all filenames for the given bundle basename and Locale. |
protected List |
calculateFilenamesForLocale(String basename,
Locale locale)
Calculate the filenames for the given bundle basename and Locale, appending language code, country code, and variant code. |
void |
clearCache()
Clear the resource bundle cache. |
void |
clearCacheIncludingAncestors()
Clear the resource bundle caches of this MessageSource and all its ancestors. |
protected ReloadableResourceBundleMessageSource.PropertiesHolder |
getMergedProperties(Locale locale)
Get a PropertiesHolder that contains the actually visible properties for a Locale, after merging all specified resource bundles. |
protected ReloadableResourceBundleMessageSource.PropertiesHolder |
getProperties(String filename)
Get a PropertiesHolder for the given filename, either from the cache or freshly loaded. |
protected ReloadableResourceBundleMessageSource.PropertiesHolder |
refreshProperties(String filename,
ReloadableResourceBundleMessageSource.PropertiesHolder propHolder)
Refresh the PropertiesHolder for the given bundle filename. |
protected MessageFormat |
resolveCode(String code,
Locale locale)
Subclasses must implement this method to resolve a message. |
protected String |
resolveCodeWithoutArguments(String code,
Locale locale)
Subclasses can override this method to resolve a message without arguments in an optimized fashion, i.e. to resolve a message without involving a MessageFormat. |
void |
setBasename(String basename)
Set a single basename, following the basic ResourceBundle convention of not specifying file extension or language codes, but in contrast to ResourceBundleMessageSource referring to a Spring resource location: e.g. |
void |
setBasenames(String[] basenames)
Set an array of basenames, each following the above-mentioned special convention. |
void |
setCacheSeconds(int cacheSeconds)
Set the number of seconds to cache loaded properties files. |
void |
setDefaultEncoding(String defaultEncoding)
Set the default charset to use for parsing properties files. |
void |
setFallbackToSystemLocale(boolean fallbackToSystemLocale)
Set whether to fall back to the system Locale if no files for a specific Locale have been found. |
void |
setFileEncodings(Properties fileEncodings)
Set per-file charsets to use for parsing properties files. |
void |
setPropertiesPersister(PropertiesPersister propertiesPersister)
Set the PropertiesPersister to use for parsing properties files. |
void |
setResourceLoader(ResourceLoader resourceLoader)
Set the ResourceLoader to use for loading bundle properties files. |
String |
toString()
|
Methods inherited from class org.springframework.context.support.AbstractMessageSource |
createMessageFormat, getMessage, getMessage, getMessage, getMessageInternal, getParentMessageSource, resolveArguments, setParentMessageSource, setUseCodeAsDefaultMessage |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
public ReloadableResourceBundleMessageSource()
Method Detail |
public void setBasename(String basename)
basename
- the single basenamesetBasenames(java.lang.String[])
,
ResourceEditor
,
ResourceBundle
public void setBasenames(String[] basenames)
Note that message definitions in a previous resource bundle will override ones in a later bundle, due to the sequential lookup.
basenames
- an array of basenamessetBasename(java.lang.String)
,
ResourceBundle
public void setDefaultEncoding(String defaultEncoding)
Default is none, using java.util.Properties' default charset.
setFileEncodings(java.util.Properties)
,
PropertiesPersister.load(java.util.Properties, java.io.InputStream)
public void setFileEncodings(Properties fileEncodings)
fileEncodings
- Properties with filenames as keys and charset
names as values. Filenames have to match the basename syntax,
with optional locale-specific appendices: e.g. "WEB-INF/messages"
or "WEB-INF/messages_en".setBasenames(java.lang.String[])
,
PropertiesPersister.load(java.util.Properties, java.io.InputStream)
public void setFallbackToSystemLocale(boolean fallbackToSystemLocale)
Falling back to the system Locale is the default behavior of java.util.ResourceBundle. However, this is often not desirable in an application server environment, where the system Locale is not relevant to the application at all: Set this flag to "false" in such a scenario.
public void setCacheSeconds(int cacheSeconds)
public void setPropertiesPersister(PropertiesPersister propertiesPersister)
DefaultPropertiesPersister
public void setResourceLoader(ResourceLoader resourceLoader)
setResourceLoader
in interface ResourceLoaderAware
resourceLoader
- ResourceLoader object to be used by this objectDefaultResourceLoader
protected String resolveCodeWithoutArguments(String code, Locale locale)
AbstractMessageSource
The default implementation does use MessageFormat,
through delegating to the resolveCode
method.
Subclasses are encouraged to replace this with optimized resolution.
Unfortunately, java.text.MessageFormat
is not
implemented in an efficient fashion. In particular, it does not
detect that a message pattern doesn't contain argument placeholders
in the first place. Therefore, it's advisable to circumvent
MessageFormat completely for messages without arguments.
resolveCodeWithoutArguments
in class AbstractMessageSource
code
- the code of the message to resolvelocale
- the Locale to resolve the code for
(subclasses are encouraged to support internationalization)
AbstractMessageSource.resolveCode(java.lang.String, java.util.Locale)
,
MessageFormat
protected MessageFormat resolveCode(String code, Locale locale)
AbstractMessageSource
Returns a MessageFormat instance rather than a message String, to allow for appropriate caching of MessageFormats in subclasses.
Subclasses are encouraged to provide optimized resolution
for messages without arguments, not involving MessageFormat.
See resolveCodeWithoutArguments
javadoc for details.
resolveCode
in class AbstractMessageSource
code
- the code of the message to resolvelocale
- the Locale to resolve the code for
(subclasses are encouraged to support internationalization)
AbstractMessageSource.resolveCodeWithoutArguments(java.lang.String, java.util.Locale)
protected ReloadableResourceBundleMessageSource.PropertiesHolder getMergedProperties(Locale locale)
Only used when caching resource bundle contents forever, i.e. with cacheSeconds < 0. Therefore, merged properties are always cached forever.
protected List calculateAllFilenames(String basename, Locale locale)
basename
- the basename of the bundlelocale
- the locale
setFallbackToSystemLocale(boolean)
,
calculateFilenamesForLocale(java.lang.String, java.util.Locale)
protected List calculateFilenamesForLocale(String basename, Locale locale)
basename
- the basename of the bundlelocale
- the locale
protected ReloadableResourceBundleMessageSource.PropertiesHolder getProperties(String filename)
protected ReloadableResourceBundleMessageSource.PropertiesHolder refreshProperties(String filename, ReloadableResourceBundleMessageSource.PropertiesHolder propHolder)
public void clearCache()
public void clearCacheIncludingAncestors()
clearCache()
public String toString()
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |