Class WebSessionFilter
- java.lang.Object
- 
- org.apache.ignite.cache.websession.WebSessionFilter
 
- 
- All Implemented Interfaces:
- javax.servlet.Filter
 
 public class WebSessionFilter extends Object implements javax.servlet.Filter Filter for web sessions caching.This is a request filter, that you need to specify in your web.xmlalong withServletContextListenerStartupto enable web sessions caching:<listener> <listener-class>org.apache.ignite.startup.servlet.ServletContextListenerStartup</listener-class> </listener> <filter> <filter-name>WebSessionFilter</filter-name> <filter-class>org.apache.ignite.cache.websession.WebSessionFilter</filter-class> </filter> <!-- You can also specify a custom URL pattern. --> <filter-mapping> <filter-name>IgniteWebSessionsFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>It is also possible to specify a servlet name in a filter mapping, and a servlet URL pattern will be used in this case:<filter> <filter-name>WebSessionFilter</filter-name> <filter-class>org.apache.ignite.cache.websession.WebSessionFilter</filter-class> </filter> <filter-mapping> <filter-name>WebSessionFilter</filter-name> <servlet-name>YourServletName</servlet-name> </filter-mapping>The filter has the following optional configuration parameters:
 These parameters are taken from either filter init parameter list or servlet context parameters. You can specify filter init parameters as follows:Name Description Default IgniteWebSessionsGridName Name of the grid that contains cache for web session storage. null(default grid)IgniteWebSessionsCacheName Name of the cache for web session storage. null(default cache)IgniteWebSessionsMaximumRetriesOnFail Valid for ATOMICcaches only. Maximum number of retries for session updates in case node leaves topology and update fails. If retry is enabled, some updates can be applied more than once, otherwise some updates can be lost.To disable retries, set this parameter to 0.3IgniteWebSessionsRetriesTimeout Retry timeout. Related to IgniteWebSessionsMaximumRetriesOnFail param. Further attempts will be cancelled in case timeout was exceeded. 10000(10 seconds)<filter> <filter-name>WebSessionFilter</filter-name> <filter-class>org.apache.ignite.cache.websession.WebSessionFilter</filter-class> <init-param> <param-name>IgniteWebSessionsGridName</param-name> <param-value>WebGrid</param-value> </init-param> <init-param> <param-name>IgniteWebSessionsCacheName</param-name> <param-value>WebCache</param-value> </init-param> <!-- Valid for ATOMIC caches only. --> <init-param> <param-name>IgniteWebSessionsMaximumRetriesOnFail</param-name> <param-value>10</param-value> </init-param> </filter>Note: filter init parameter has a priority over servlet context parameter; if you specify both, the servlet context parameter will be ignored.Web sessions caching and concurrent requestsIf your web application can accept concurrent request for one session, consider usingCacheAtomicityMode.TRANSACTIONALcache instead ofCacheAtomicityMode.ATOMIC. In this case each request be processed inside pessimistic transaction which will guarantee that all updates will be applied in correct order. This is important, for example, if you get some attribute from the session, update its value and set new value back to the session. In case ofCacheAtomicityMode.ATOMICcache concurrent requests can get equal value, butCacheAtomicityMode.TRANSACTIONALcache will always process such updates one after another.
- 
- 
Field SummaryFields Modifier and Type Field Description static booleanDFLT_KEEP_BINARY_FLAGDefault keep binary flag.static intDFLT_MAX_RETRIES_ON_FAILDefault retry on fail flag value.static intDFLT_RETRIES_ON_FAIL_TIMEOUTDefault retry on fail timeout flag value.static StringWEB_SES_CACHE_NAME_PARAMWeb sessions caching cache name parameter name.static StringWEB_SES_KEEP_BINARY_PARAMstatic StringWEB_SES_MAX_RETRIES_ON_FAIL_NAME_PARAMWeb sessions caching retry on fail parameter name (valid for ATOMIC cache only).static StringWEB_SES_NAME_PARAMWeb sessions caching grid name parameter name.static StringWEB_SES_RETRIES_TIMEOUT_NAME_PARAMWeb sessions caching retry on fail timeout parameter name.
 - 
Constructor SummaryConstructors Constructor Description WebSessionFilter()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voiddestroy()voiddestroySession(String sesId)voiddoFilter(javax.servlet.ServletRequest req, javax.servlet.ServletResponse res, javax.servlet.FilterChain chain)voidinit(javax.servlet.FilterConfig cfg)StringtoString()voidupdateAttributes(String sesId, Collection<org.apache.ignite.internal.util.typedef.T2<String,Object>> updates, int maxInactiveInterval)voidupdateAttributesV2(String sesId, org.apache.ignite.cache.websession.WebSessionV2 ses)
 
- 
- 
- 
Field Detail- 
WEB_SES_NAME_PARAMpublic static final String WEB_SES_NAME_PARAM Web sessions caching grid name parameter name.- See Also:
- Constant Field Values
 
 - 
WEB_SES_CACHE_NAME_PARAMpublic static final String WEB_SES_CACHE_NAME_PARAM Web sessions caching cache name parameter name.- See Also:
- Constant Field Values
 
 - 
WEB_SES_MAX_RETRIES_ON_FAIL_NAME_PARAMpublic static final String WEB_SES_MAX_RETRIES_ON_FAIL_NAME_PARAM Web sessions caching retry on fail parameter name (valid for ATOMIC cache only).- See Also:
- Constant Field Values
 
 - 
WEB_SES_RETRIES_TIMEOUT_NAME_PARAMpublic static final String WEB_SES_RETRIES_TIMEOUT_NAME_PARAM Web sessions caching retry on fail timeout parameter name.- See Also:
- Constant Field Values
 
 - 
WEB_SES_KEEP_BINARY_PARAMpublic static final String WEB_SES_KEEP_BINARY_PARAM - See Also:
- Constant Field Values
 
 - 
DFLT_MAX_RETRIES_ON_FAILpublic static final int DFLT_MAX_RETRIES_ON_FAIL Default retry on fail flag value.- See Also:
- Constant Field Values
 
 - 
DFLT_RETRIES_ON_FAIL_TIMEOUTpublic static final int DFLT_RETRIES_ON_FAIL_TIMEOUT Default retry on fail timeout flag value.- See Also:
- Constant Field Values
 
 - 
DFLT_KEEP_BINARY_FLAGpublic static final boolean DFLT_KEEP_BINARY_FLAG Default keep binary flag.- See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
initpublic void init(javax.servlet.FilterConfig cfg) throws javax.servlet.ServletException- Specified by:
- initin interface- javax.servlet.Filter
- Throws:
- javax.servlet.ServletException
 
 - 
destroypublic void destroy() - Specified by:
- destroyin interface- javax.servlet.Filter
 
 - 
doFilterpublic void doFilter(javax.servlet.ServletRequest req, javax.servlet.ServletResponse res, javax.servlet.FilterChain chain) throws IOException, javax.servlet.ServletException- Specified by:
- doFilterin interface- javax.servlet.Filter
- Throws:
- IOException
- javax.servlet.ServletException
 
 - 
destroySessionpublic void destroySession(String sesId) - Parameters:
- sesId- Session ID.
 
 - 
updateAttributespublic void updateAttributes(String sesId, Collection<org.apache.ignite.internal.util.typedef.T2<String,Object>> updates, int maxInactiveInterval) - Parameters:
- sesId- Session ID.
- updates- Updates list.
- maxInactiveInterval- Max session inactive interval.
 
 - 
updateAttributesV2public void updateAttributesV2(String sesId, org.apache.ignite.cache.websession.WebSessionV2 ses) throws IOException - Parameters:
- sesId- Session ID.
- ses- Web session.
- Throws:
- IOException
 
 
- 
 
-