Class CookieLocaleResolver
- All Implemented Interfaces:
LocaleContextResolver
,LocaleResolver
LocaleResolver
implementation that uses a cookie sent back to the user
in case of a custom setting, with a fallback to the configured default locale,
the request's Accept-Language
header, or the default locale for the server.
This is particularly useful for stateless applications without user sessions. The cookie may optionally contain an associated time zone value as well; alternatively, you may specify a default time zone.
Custom controllers can override the user's locale and time zone by calling
#setLocale(Context)
on the resolver, for example, responding to a locale change
request. As a more convenient alternative, consider using
RequestContext.changeLocale(java.util.Locale)
.
- Since:
- 27.02.2003
- Author:
- Juergen Hoeller, Jean-Pierre Pawlak, Vedran Pavic, Sam Brannen
- See Also:
-
Field Summary
-
Constructor Summary
ConstructorDescriptionConstructor with a default cookie name.CookieLocaleResolver
(String cookieName) Constructor with a given cookie name. -
Method Summary
Modifier and TypeMethodDescriptionprotected Locale
determineDefaultLocale
(HttpServletRequest request) Deprecated.protected TimeZone
Deprecated.as of 6.0, in favor ofsetDefaultTimeZoneFunction(Function)
boolean
Return whether this resolver's cookies should be compliant with BCP 47 language tags instead of Java's legacy locale specification format.boolean
Return whether to reject cookies with invalid content (for example, invalid format).protected Locale
parseLocaleValue
(String localeValue) Parse the given locale value coming from an incoming cookie.resolveLocale
(HttpServletRequest request) Default implementation ofLocaleResolver.resolveLocale(HttpServletRequest)
that delegates toLocaleContextResolver.resolveLocaleContext(HttpServletRequest)
, falling back toServletRequest.getLocale()
if necessary.resolveLocaleContext
(HttpServletRequest request) Resolve the current locale context via the given request.void
setCookieDomain
(String cookieDomain) Set the cookie "Domain" attribute.void
setCookieHttpOnly
(boolean cookieHttpOnly) Add the "HttpOnly" attribute to the cookie.void
setCookieMaxAge
(Integer cookieMaxAge) Deprecated.as of 6.0 in favor ofsetCookieMaxAge(Duration)
void
setCookieMaxAge
(Duration cookieMaxAge) Set the cookie "Max-Age" attribute.void
setCookieName
(String cookieName) Deprecated.as of 6.0 in favor ofCookieLocaleResolver(String)
void
setCookiePath
(String cookiePath) Set the cookie "Path" attribute.void
setCookieSameSite
(String cookieSameSite) Add the "SameSite" attribute to the cookie.void
setCookieSecure
(boolean cookieSecure) Add the "Secure" attribute to the cookie.void
setDefaultLocaleFunction
(Function<HttpServletRequest, Locale> defaultLocaleFunction) Set the function used to determine the default locale for the given request, called if no locale cookie has been found.void
setDefaultTimeZoneFunction
(Function<HttpServletRequest, TimeZone> defaultTimeZoneFunction) Set the function used to determine the default time zone for the given request, called if no locale cookie has been found.void
setLanguageTagCompliant
(boolean languageTagCompliant) Specify whether this resolver's cookies should be compliant with BCP 47 language tags instead of Java's legacy locale specification format.void
setLocaleContext
(HttpServletRequest request, HttpServletResponse response, LocaleContext localeContext) Set the current locale context to the given one, potentially including a locale with associated time zone information.void
setRejectInvalidCookies
(boolean rejectInvalidCookies) Specify whether to reject cookies with invalid content (for example, invalid format).protected String
toLocaleValue
(Locale locale) Render the given locale as a text value for inclusion in a cookie.Methods inherited from class org.springframework.web.servlet.i18n.AbstractLocaleContextResolver
getDefaultTimeZone, setDefaultTimeZone
Methods inherited from class org.springframework.web.servlet.i18n.AbstractLocaleResolver
getDefaultLocale, setDefaultLocale
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface org.springframework.web.servlet.LocaleContextResolver
setLocale
-
Field Details
-
LOCALE_REQUEST_ATTRIBUTE_NAME
The name of the request attribute that holds theLocale
.Only used for overriding a cookie value if the locale has been changed in the course of the current request!
Use
RequestContext(Utils).getLocale()
to retrieve the current locale in controllers or views. -
TIME_ZONE_REQUEST_ATTRIBUTE_NAME
The name of the request attribute that holds theTimeZone
.Only used for overriding a cookie value if the locale has been changed in the course of the current request!
Use
RequestContext(Utils).getTimeZone()
to retrieve the current time zone in controllers or views. -
DEFAULT_COOKIE_NAME
The default cookie name used if none is explicitly set.
-
-
Constructor Details
-
CookieLocaleResolver
Constructor with a given cookie name.- Since:
- 6.0
-
CookieLocaleResolver
public CookieLocaleResolver()Constructor with a default cookie name.
-
-
Method Details
-
setCookieName
Deprecated.as of 6.0 in favor ofCookieLocaleResolver(String)
Set the name of cookie created by this resolver.- Parameters:
cookieName
- the cookie name
-
setCookieMaxAge
Set the cookie "Max-Age" attribute.By default, this is set to -1 in which case the cookie persists until browser shutdown.
- Since:
- 6.0
- See Also:
-
setCookieMaxAge
Deprecated.as of 6.0 in favor ofsetCookieMaxAge(Duration)
Variant ofsetCookieMaxAge(Duration)
with a value in seconds. -
setCookiePath
Set the cookie "Path" attribute.By default, this is set to
"/"
. -
setCookieDomain
Set the cookie "Domain" attribute. -
setCookieSecure
public void setCookieSecure(boolean cookieSecure) Add the "Secure" attribute to the cookie. -
setCookieHttpOnly
public void setCookieHttpOnly(boolean cookieHttpOnly) Add the "HttpOnly" attribute to the cookie. -
setCookieSameSite
Add the "SameSite" attribute to the cookie.By default, this is set to
"Lax"
.- Since:
- 6.0
- See Also:
-
setLanguageTagCompliant
public void setLanguageTagCompliant(boolean languageTagCompliant) Specify whether this resolver's cookies should be compliant with BCP 47 language tags instead of Java's legacy locale specification format.The default is
true
, as of 5.1. Switch this tofalse
for rendering Java's legacy locale specification format. For parsing, this resolver leniently accepts the legacyLocale.toString()
format as well as BCP 47 language tags in any case.- Since:
- 4.3
- See Also:
-
isLanguageTagCompliant
public boolean isLanguageTagCompliant()Return whether this resolver's cookies should be compliant with BCP 47 language tags instead of Java's legacy locale specification format.- Since:
- 4.3
-
setRejectInvalidCookies
public void setRejectInvalidCookies(boolean rejectInvalidCookies) Specify whether to reject cookies with invalid content (for example, invalid format).The default is
true
. Turn this off for lenient handling of parse failures, falling back to the default locale and time zone in such a case. -
isRejectInvalidCookies
public boolean isRejectInvalidCookies()Return whether to reject cookies with invalid content (for example, invalid format).- Since:
- 5.1.7
-
setDefaultLocaleFunction
Set the function used to determine the default locale for the given request, called if no locale cookie has been found.The default implementation returns the configured default locale, if any, and otherwise falls back to the request's
Accept-Language
header locale or the default locale for the server.- Parameters:
defaultLocaleFunction
- the function used to determine the default locale- Since:
- 6.0
- See Also:
-
setDefaultTimeZoneFunction
public void setDefaultTimeZoneFunction(Function<HttpServletRequest, TimeZone> defaultTimeZoneFunction) Set the function used to determine the default time zone for the given request, called if no locale cookie has been found.The default implementation returns the configured default time zone, if any, or
null
otherwise.- Parameters:
defaultTimeZoneFunction
- the function used to determine the default time zone- Since:
- 6.0
- See Also:
-
resolveLocale
Description copied from interface:LocaleContextResolver
Default implementation ofLocaleResolver.resolveLocale(HttpServletRequest)
that delegates toLocaleContextResolver.resolveLocaleContext(HttpServletRequest)
, falling back toServletRequest.getLocale()
if necessary.- Parameters:
request
- the request to resolve the locale for- Returns:
- the current locale (never
null
)
-
resolveLocaleContext
Description copied from interface:LocaleContextResolver
Resolve the current locale context via the given request.This is primarily intended for framework-level processing; consider using
RequestContextUtils
orRequestContext
for application-level access to the current locale and/or time zone.The returned context may be a
TimeZoneAwareLocaleContext
, containing a locale with associated time zone information. Simply apply aninstanceof
check and downcast accordingly.Custom resolver implementations may also return extra settings in the returned context, which again can be accessed through downcasting.
- Parameters:
request
- the request to resolve the locale context for- Returns:
- the current locale context (never
null
- See Also:
-
setLocaleContext
public void setLocaleContext(HttpServletRequest request, @Nullable HttpServletResponse response, @Nullable LocaleContext localeContext) Description copied from interface:LocaleContextResolver
Set the current locale context to the given one, potentially including a locale with associated time zone information.- Parameters:
request
- the request to be used for locale modificationresponse
- the response to be used for locale modificationlocaleContext
- the new locale context, ornull
to clear the locale- See Also:
-
parseLocaleValue
Parse the given locale value coming from an incoming cookie.The default implementation calls
StringUtils.parseLocale(String)
, accepting theLocale.toString()
format as well as BCP 47 language tags.- Parameters:
localeValue
- the locale value to parse- Returns:
- the corresponding
Locale
instance - Since:
- 4.3
- See Also:
-
toLocaleValue
Render the given locale as a text value for inclusion in a cookie.The default implementation calls
Locale.toString()
orLocale.toLanguageTag()
, depending on the"languageTagCompliant"
configuration property.- Parameters:
locale
- the locale to convert to a string- Returns:
- a String representation for the given locale
- Since:
- 4.3
- See Also:
-
determineDefaultLocale
Deprecated.as of 6.0, in favor ofsetDefaultLocaleFunction(Function)
Determine the default locale for the given request, called if no locale cookie has been found.The default implementation returns the configured default locale, if any, and otherwise falls back to the request's
Accept-Language
header locale or the default locale for the server.- Parameters:
request
- the request to resolve the locale for- Returns:
- the default locale (never
null
) - See Also:
-
determineDefaultTimeZone
@Deprecated(since="6.0") @Nullable protected TimeZone determineDefaultTimeZone(HttpServletRequest request) Deprecated.as of 6.0, in favor ofsetDefaultTimeZoneFunction(Function)
Determine the default time zone for the given request, called if no locale cookie has been found.The default implementation returns the configured default time zone, if any, or
null
otherwise.- Parameters:
request
- the request to resolve the time zone for- Returns:
- the default time zone (or
null
if none defined) - See Also:
-
setDefaultLocaleFunction(Function)