public class SessionThemeResolver extends AbstractThemeResolver
ThemeResolver implementation that
 uses a theme attribute in the user's session in case of a custom setting,
 with a fallback to the default theme. This is most appropriate if the
 application needs user sessions anyway.
 Custom controllers can override the user's theme by calling
 setThemeName, e.g. responding to a theme change request.
setThemeName(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse, java.lang.String)| Modifier and Type | Field and Description | 
|---|---|
| static String | THEME_SESSION_ATTRIBUTE_NAMEName of the session attribute that holds the theme name. | 
ORIGINAL_DEFAULT_THEME_NAME| Constructor and Description | 
|---|
| SessionThemeResolver() | 
| Modifier and Type | Method and Description | 
|---|---|
| String | resolveThemeName(HttpServletRequest request)Resolve the current theme name via the given request. | 
| void | setThemeName(HttpServletRequest request,
            HttpServletResponse response,
            String themeName)Set the current theme name to the given one. | 
getDefaultThemeName, setDefaultThemeNamepublic static final String THEME_SESSION_ATTRIBUTE_NAME
RequestContext(Utils).getTheme()
 to retrieve the current theme in controllers or views.public String resolveThemeName(HttpServletRequest request)
ThemeResolverrequest - the request to be used for resolutionpublic void setThemeName(HttpServletRequest request, @Nullable HttpServletResponse response, @Nullable String themeName)
ThemeResolverrequest - the request to be used for theme name modificationresponse - the response to be used for theme name modificationthemeName - the new theme name (null or empty to reset it)