Package org.apache.catalina.session
Class DataSourceStore
- java.lang.Object
- 
- org.apache.catalina.util.LifecycleBase
- 
- org.apache.catalina.session.StoreBase
- 
- org.apache.catalina.session.DataSourceStore
 
 
 
- 
- 
Nested Class Summary- 
Nested classes/interfaces inherited from interface org.apache.catalina.LifecycleLifecycle.SingleUse
 
- 
 - 
Field SummaryFields Modifier and Type Field Description protected DataSourcedataSourceDataSource to useprotected StringdataSourceNamename of the JNDI resourceprotected StringsessionAppColColumn to use for /Engine/Host/Context nameprotected StringsessionDataColData column to use.protected StringsessionIdColId column to use.protected StringsessionLastAccessedColLast Accessed column to use.protected StringsessionMaxInactiveColMax Inactive column to use.protected StringsessionTableTable to use.protected StringsessionValidColIs Validcolumn to use.protected static StringstoreNameName to register for this Store, used for logging.- 
Fields inherited from interface org.apache.catalina.LifecycleAFTER_DESTROY_EVENT, AFTER_INIT_EVENT, AFTER_START_EVENT, AFTER_STOP_EVENT, BEFORE_DESTROY_EVENT, BEFORE_INIT_EVENT, BEFORE_START_EVENT, BEFORE_STOP_EVENT, CONFIGURE_START_EVENT, CONFIGURE_STOP_EVENT, PERIODIC_EVENT, START_EVENT, STOP_EVENT
 
- 
 - 
Constructor SummaryConstructors Constructor Description DataSourceStore()
 - 
Method SummaryAll Methods Instance Methods Concrete Methods Modifier and Type Method Description voidclear()Remove all of the Sessions in this Store.protected voidclose(Connection dbConnection)Close the specified database connection.String[]expiredKeys()Get only those keys of sessions, that are saved in the Store and are to be expired.protected ConnectiongetConnection()Check the connection associated with this store, if it'snullor closed try to reopen it.StringgetDataSourceName()booleangetLocalDataSource()StringgetName()StringgetSessionAppCol()StringgetSessionDataCol()StringgetSessionIdCol()StringgetSessionLastAccessedCol()StringgetSessionMaxInactiveCol()StringgetSessionTable()StringgetSessionValidCol()intgetSize()Return an integer containing a count of all Sessions currently saved in this Store.StringgetStoreName()String[]keys()Sessionload(String id)Load the Session associated with the idid.protected Connectionopen()Open (if necessary) and return a database connection for use by this Store.protected voidrelease(Connection conn)Release the connection, if it is associated with a connection pool.voidremove(String id)Remove the Session with the specified session identifier from this Store, if present.voidsave(Session session)Save a session to the Store.voidsetDataSourceName(String dataSourceName)Set the JNDI name of a DataSource-factory to use for db accessvoidsetLocalDataSource(boolean localDataSource)Set totrueto cause the datasource to be looked up in the webapp JNDI Context.voidsetSessionAppCol(String sessionAppCol)Set the App column for the table.voidsetSessionDataCol(String sessionDataCol)Set the Data column for the tablevoidsetSessionIdCol(String sessionIdCol)Set the Id column for the table.voidsetSessionLastAccessedCol(String sessionLastAccessedCol)Set theLast Accessedcolumn for the tablevoidsetSessionMaxInactiveCol(String sessionMaxInactiveCol)Set theMax Inactivecolumn for the tablevoidsetSessionTable(String sessionTable)Set the table for this Store.voidsetSessionValidCol(String sessionValidCol)Set theIs Validcolumn for the table- 
Methods inherited from class org.apache.catalina.session.StoreBaseaddPropertyChangeListener, destroyInternal, getManager, getObjectInputStream, initInternal, processExpires, removePropertyChangeListener, setManager, startInternal, stopInternal, toString
 - 
Methods inherited from class org.apache.catalina.util.LifecycleBaseaddLifecycleListener, destroy, findLifecycleListeners, fireLifecycleEvent, getState, getStateName, getThrowOnFailure, init, removeLifecycleListener, setState, setState, setThrowOnFailure, start, stop
 
- 
 
- 
- 
- 
Field Detail- 
storeNameprotected static final String storeName Name to register for this Store, used for logging.- See Also:
- Constant Field Values
 
 - 
dataSourceNameprotected String dataSourceName name of the JNDI resource
 - 
dataSourceprotected DataSource dataSource DataSource to use
 - 
sessionTableprotected String sessionTable Table to use.
 - 
sessionAppColprotected String sessionAppCol Column to use for /Engine/Host/Context name
 - 
sessionIdColprotected String sessionIdCol Id column to use.
 - 
sessionDataColprotected String sessionDataCol Data column to use.
 - 
sessionValidColprotected String sessionValidCol Is Validcolumn to use.
 - 
sessionMaxInactiveColprotected String sessionMaxInactiveCol Max Inactive column to use.
 - 
sessionLastAccessedColprotected String sessionLastAccessedCol Last Accessed column to use.
 
- 
 - 
Method Detail- 
getNamepublic String getName() - Returns:
- the name for this instance (built from container name)
 
 - 
getStoreNamepublic String getStoreName() - Overrides:
- getStoreNamein class- StoreBase
- Returns:
- the name for this Store, used for logging.
 
 - 
setSessionTablepublic void setSessionTable(String sessionTable) Set the table for this Store.- Parameters:
- sessionTable- The new table
 
 - 
getSessionTablepublic String getSessionTable() - Returns:
- the table for this Store.
 
 - 
setSessionAppColpublic void setSessionAppCol(String sessionAppCol) Set the App column for the table.- Parameters:
- sessionAppCol- the column name
 
 - 
getSessionAppColpublic String getSessionAppCol() - Returns:
- the web application name column for the table.
 
 - 
setSessionIdColpublic void setSessionIdCol(String sessionIdCol) Set the Id column for the table.- Parameters:
- sessionIdCol- the column name
 
 - 
getSessionIdColpublic String getSessionIdCol() - Returns:
- the Id column for the table.
 
 - 
setSessionDataColpublic void setSessionDataCol(String sessionDataCol) Set the Data column for the table- Parameters:
- sessionDataCol- the column name
 
 - 
getSessionDataColpublic String getSessionDataCol() - Returns:
- the data column for the table
 
 - 
setSessionValidColpublic void setSessionValidCol(String sessionValidCol) Set theIs Validcolumn for the table- Parameters:
- sessionValidCol- The column name
 
 - 
getSessionValidColpublic String getSessionValidCol() - Returns:
- the Is Validcolumn
 
 - 
setSessionMaxInactiveColpublic void setSessionMaxInactiveCol(String sessionMaxInactiveCol) Set theMax Inactivecolumn for the table- Parameters:
- sessionMaxInactiveCol- The column name
 
 - 
getSessionMaxInactiveColpublic String getSessionMaxInactiveCol() - Returns:
- the Max Inactivecolumn
 
 - 
setSessionLastAccessedColpublic void setSessionLastAccessedCol(String sessionLastAccessedCol) Set theLast Accessedcolumn for the table- Parameters:
- sessionLastAccessedCol- The column name
 
 - 
getSessionLastAccessedColpublic String getSessionLastAccessedCol() - Returns:
- the Last Accessedcolumn
 
 - 
setDataSourceNamepublic void setDataSourceName(String dataSourceName) Set the JNDI name of a DataSource-factory to use for db access- Parameters:
- dataSourceName- The JNDI name of the DataSource-factory
 
 - 
getDataSourceNamepublic String getDataSourceName() - Returns:
- the name of the JNDI DataSource-factory
 
 - 
getLocalDataSourcepublic boolean getLocalDataSource() - Returns:
- if the datasource will be looked up in the webapp JNDI Context.
 
 - 
setLocalDataSourcepublic void setLocalDataSource(boolean localDataSource) Set totrueto cause the datasource to be looked up in the webapp JNDI Context.- Parameters:
- localDataSource- the new flag value
 
 - 
expiredKeyspublic String[] expiredKeys() throws IOException Description copied from class:StoreBaseGet only those keys of sessions, that are saved in the Store and are to be expired.- Overrides:
- expiredKeysin class- StoreBase
- Returns:
- list of session keys, that are to be expired
- Throws:
- IOException- if an input-/output error occurred
 
 - 
keyspublic String[] keys() throws IOException - Returns:
- an array containing the session identifiers of all Sessions currently saved in this Store. If there are no such Sessions, a zero-length array is returned.
- Throws:
- IOException- if an input/output error occurred
 
 - 
getSizepublic int getSize() throws IOExceptionReturn an integer containing a count of all Sessions currently saved in this Store. If there are no Sessions,0is returned.- Returns:
- the count of all sessions currently saved in this Store
- Throws:
- IOException- if an input/output error occurred
 
 - 
loadpublic Session load(String id) throws ClassNotFoundException, IOException Load the Session associated with the idid. If no such session is foundnullis returned.- Parameters:
- id- a value of type- String
- Returns:
- the stored Session
- Throws:
- ClassNotFoundException- if an error occurs
- IOException- if an input/output error occurred
 
 - 
removepublic void remove(String id) throws IOException Remove the Session with the specified session identifier from this Store, if present. If no such Session is present, this method takes no action.- Parameters:
- id- Session identifier of the Session to be removed
- Throws:
- IOException- if an input/output error occurs
 
 - 
clearpublic void clear() throws IOExceptionRemove all of the Sessions in this Store.- Throws:
- IOException- if an input/output error occurs
 
 - 
savepublic void save(Session session) throws IOException Save a session to the Store.- Parameters:
- session- the session to be stored
- Throws:
- IOException- if an input/output error occurs
 
 - 
getConnectionprotected Connection getConnection() Check the connection associated with this store, if it'snullor closed try to reopen it. Returnsnullif the connection could not be established.- Returns:
- Connectionif the connection succeeded
 
 - 
openprotected Connection open() throws SQLException Open (if necessary) and return a database connection for use by this Store.- Returns:
- database connection ready to use
- Throws:
- SQLException- if a database error occurs
 
 - 
closeprotected void close(Connection dbConnection) Close the specified database connection.- Parameters:
- dbConnection- The connection to be closed
 
 - 
releaseprotected void release(Connection conn) Release the connection, if it is associated with a connection pool.- Parameters:
- conn- The connection to be released
 
 
- 
 
-