Class LocaleContextHolder
inheritable flag is set to true.
 Used as a central holder for the current Locale in Spring, wherever necessary: for example, in MessageSourceAccessor. DispatcherServlet automatically exposes its current Locale here. Other applications can expose theirs too, to make classes like MessageSourceAccessor automatically use that Locale.
- Since:
- 1.2
- Author:
- Juergen Hoeller, Nicholas Williams
- See Also:
- 
Method SummaryModifier and TypeMethodDescriptionstatic LocaleReturn the Locale associated with the current thread, if any, or the system default Locale otherwise.static LocalegetLocale(LocaleContext localeContext) Return the Locale associated with the given user context, if any, or the system default Locale otherwise.static LocaleContextReturn the LocaleContext associated with the current thread, if any.static TimeZoneReturn the TimeZone associated with the current thread, if any, or the system default TimeZone otherwise.static TimeZonegetTimeZone(LocaleContext localeContext) Return the TimeZone associated with the given user context, if any, or the system default TimeZone otherwise.static voidReset the LocaleContext for the current thread.static voidsetDefaultLocale(Locale locale) Set a shared default locale at the framework level, as an alternative to the JVM-wide default locale.static voidsetDefaultTimeZone(TimeZone timeZone) Set a shared default time zone at the framework level, as an alternative to the JVM-wide default time zone.static voidAssociate the given Locale with the current thread, preserving any TimeZone that may have been set already.static voidAssociate the given Locale with the current thread, preserving any TimeZone that may have been set already.static voidsetLocaleContext(LocaleContext localeContext) Associate the given LocaleContext with the current thread, not exposing it as inheritable for child threads.static voidsetLocaleContext(LocaleContext localeContext, boolean inheritable) Associate the given LocaleContext with the current thread.static voidsetTimeZone(TimeZone timeZone) Associate the given TimeZone with the current thread, preserving any Locale that may have been set already.static voidsetTimeZone(TimeZone timeZone, boolean inheritable) Associate the given TimeZone with the current thread, preserving any Locale that may have been set already.
- 
Method Details- 
resetLocaleContextpublic static void resetLocaleContext()Reset the LocaleContext for the current thread.
- 
setLocaleContextAssociate the given LocaleContext with the current thread, not exposing it as inheritable for child threads.The given LocaleContext may be a TimeZoneAwareLocaleContext, containing a locale with associated time zone information.- Parameters:
- localeContext- the current LocaleContext, or- nullto reset the thread-bound context
- See Also:
 
- 
setLocaleContextAssociate the given LocaleContext with the current thread.The given LocaleContext may be a TimeZoneAwareLocaleContext, containing a locale with associated time zone information.- Parameters:
- localeContext- the current LocaleContext, or- nullto reset the thread-bound context
- inheritable- whether to expose the LocaleContext as inheritable for child threads (using an- InheritableThreadLocal)
- See Also:
 
- 
getLocaleContextReturn the LocaleContext associated with the current thread, if any.- Returns:
- the current LocaleContext, or nullif none
 
- 
setLocaleAssociate the given Locale with the current thread, preserving any TimeZone that may have been set already.Will implicitly create a LocaleContext for the given Locale, not exposing it as inheritable for child threads. - Parameters:
- locale- the current Locale, or- nullto reset the locale part of thread-bound context
- See Also:
 
- 
setLocaleAssociate the given Locale with the current thread, preserving any TimeZone that may have been set already.Will implicitly create a LocaleContext for the given Locale. - Parameters:
- locale- the current Locale, or- nullto reset the locale part of thread-bound context
- inheritable- whether to expose the LocaleContext as inheritable for child threads (using an- InheritableThreadLocal)
- See Also:
 
- 
setDefaultLocaleSet a shared default locale at the framework level, as an alternative to the JVM-wide default locale.NOTE: This can be useful to set an application-level default locale which differs from the JVM-wide default locale. However, this requires each such application to operate against locally deployed Spring Framework jars. Do not deploy Spring as a shared library at the server level in such a scenario! - Parameters:
- locale- the default locale (or- nullfor none, letting lookups fall back to- Locale.getDefault())
- Since:
- 4.3.5
- See Also:
 
- 
getLocaleReturn the Locale associated with the current thread, if any, or the system default Locale otherwise. This is effectively a replacement forLocale.getDefault(), able to optionally respect a user-level Locale setting.Note: This method has a fallback to the shared default Locale, either at the framework level or at the JVM-wide system level. If you'd like to check for the raw LocaleContext content (which may indicate no specific locale through null, usegetLocaleContext()and callLocaleContext.getLocale()- Returns:
- the current Locale, or the system default Locale if no specific Locale has been associated with the current thread
- See Also:
 
- 
getLocaleReturn the Locale associated with the given user context, if any, or the system default Locale otherwise. This is effectively a replacement forLocale.getDefault(), able to optionally respect a user-level Locale setting.- Parameters:
- localeContext- the user-level locale context to check
- Returns:
- the current Locale, or the system default Locale if no specific Locale has been associated with the current thread
- Since:
- 5.0
- See Also:
 
- 
setTimeZoneAssociate the given TimeZone with the current thread, preserving any Locale that may have been set already.Will implicitly create a LocaleContext for the given Locale, not exposing it as inheritable for child threads. - Parameters:
- timeZone- the current TimeZone, or- nullto reset the time zone part of the thread-bound context
- See Also:
 
- 
setTimeZoneAssociate the given TimeZone with the current thread, preserving any Locale that may have been set already.Will implicitly create a LocaleContext for the given Locale. - Parameters:
- timeZone- the current TimeZone, or- nullto reset the time zone part of the thread-bound context
- inheritable- whether to expose the LocaleContext as inheritable for child threads (using an- InheritableThreadLocal)
- See Also:
 
- 
setDefaultTimeZoneSet a shared default time zone at the framework level, as an alternative to the JVM-wide default time zone.NOTE: This can be useful to set an application-level default time zone which differs from the JVM-wide default time zone. However, this requires each such application to operate against locally deployed Spring Framework jars. Do not deploy Spring as a shared library at the server level in such a scenario! - Parameters:
- timeZone- the default time zone (or- nullfor none, letting lookups fall back to- TimeZone.getDefault())
- Since:
- 4.3.5
- See Also:
 
- 
getTimeZoneReturn the TimeZone associated with the current thread, if any, or the system default TimeZone otherwise. This is effectively a replacement forTimeZone.getDefault(), able to optionally respect a user-level TimeZone setting.Note: This method has a fallback to the shared default TimeZone, either at the framework level or at the JVM-wide system level. If you'd like to check for the raw LocaleContext content (which may indicate no specific time zone through null, usegetLocaleContext()and callTimeZoneAwareLocaleContext.getTimeZone()after downcasting toTimeZoneAwareLocaleContext.- Returns:
- the current TimeZone, or the system default TimeZone if no specific TimeZone has been associated with the current thread
- See Also:
 
- 
getTimeZoneReturn the TimeZone associated with the given user context, if any, or the system default TimeZone otherwise. This is effectively a replacement forTimeZone.getDefault(), able to optionally respect a user-level TimeZone setting.- Parameters:
- localeContext- the user-level locale context to check
- Returns:
- the current TimeZone, or the system default TimeZone if no specific TimeZone has been associated with the current thread
- Since:
- 5.0
- See Also:
 
 
-