|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.springframework.orm.hibernate4.support.OpenSessionInViewInterceptor
public class OpenSessionInViewInterceptor
Spring web request interceptor that binds a Hibernate Session
to the
thread for the entire processing of the request.
This class is a concrete expression of the "Open Session in View" pattern, which is a pattern that allows for the lazy loading of associations in web views despite the original transactions already being completed.
This interceptor makes Hibernate Sessions available via the current thread,
which will be autodetected by transaction managers. It is suitable for service layer
transactions via HibernateTransactionManager
as well as for non-transactional execution (if configured appropriately).
NOTE: This interceptor will by default not flush the Hibernate
Session
, with the flush mode being set to FlushMode.NEVER
.
It assumes that it will be used in combination with service layer transactions
that handle the flushing: the active transaction manager will temporarily change
the flush mode to FlushMode.AUTO
during a read-write transaction,
with the flush mode reset to FlushMode.NEVER
at the end of each
transaction. If you intend to use this interceptor without transactions, consider
changing the default flush mode (through the "flushMode"
property).
In contrast to OpenSessionInViewFilter
, this interceptor is configured
in a Spring application context and can thus take advantage of bean wiring..
WARNING: Applying this interceptor to existing logic can cause issues
that have not appeared before, through the use of a single Hibernate
Session
for the processing of an entire request. In particular, the
reassociation of persistent objects with a Hibernate Session
has to
occur at the very beginning of request processing, to avoid clashes with already
loaded instances of the same objects.
#setSingleSession
,
#setFlushMode
,
OpenSessionInViewFilter
,
HibernateTransactionManager
,
TransactionSynchronizationManager
Field Summary | |
---|---|
protected Log |
logger
|
static String |
PARTICIPATE_SUFFIX
Suffix that gets appended to the SessionFactory
toString() representation for the "participate in existing
session handling" request attribute. |
Constructor Summary | |
---|---|
OpenSessionInViewInterceptor()
|
Method Summary | |
---|---|
void |
afterCompletion(WebRequest request,
Exception ex)
Unbind the Hibernate Session from the thread and close it). |
protected String |
getParticipateAttributeName()
Return the name of the request attribute that identifies that a request is already intercepted. |
SessionFactory |
getSessionFactory()
|
protected Session |
openSession()
Open a Session for the SessionFactory that this interceptor uses. |
void |
postHandle(WebRequest request,
ModelMap model)
Intercept the execution of a request handler after its successful invocation, right before view rendering (if any). |
void |
preHandle(WebRequest request)
Open a new Hibernate Session according to the settings of this
HibernateAccessor and bind it to the thread via the
TransactionSynchronizationManager . |
void |
setSessionFactory(SessionFactory sessionFactory)
|
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
public static final String PARTICIPATE_SUFFIX
SessionFactory
toString()
representation for the "participate in existing
session handling" request attribute.
getParticipateAttributeName()
,
Constant Field Valuesprotected final Log logger
Constructor Detail |
---|
public OpenSessionInViewInterceptor()
Method Detail |
---|
public void setSessionFactory(SessionFactory sessionFactory)
public SessionFactory getSessionFactory()
public void preHandle(WebRequest request) throws DataAccessException
Session
according to the settings of this
HibernateAccessor
and bind it to the thread via the
TransactionSynchronizationManager
.
preHandle
in interface WebRequestInterceptor
request
- the current web request
DataAccessException
public void postHandle(WebRequest request, ModelMap model)
WebRequestInterceptor
Allows for modifying context resources after successful handler execution (for example, flushing a Hibernate Session).
postHandle
in interface WebRequestInterceptor
request
- the current web requestmodel
- the map of model objects that will be exposed to the view
(may be null
). Can be used to analyze the exposed model
and/or to add further model attributes, if desired.public void afterCompletion(WebRequest request, Exception ex) throws DataAccessException
Session
from the thread and close it).
afterCompletion
in interface WebRequestInterceptor
request
- the current web requestex
- exception thrown on handler execution, if any
DataAccessException
TransactionSynchronizationManager
protected Session openSession() throws DataAccessResourceFailureException
The default implementation delegates to the
SessionFactory.openSession
method and
sets the Session
's flush mode to "MANUAL".
DataAccessResourceFailureException
- if the Session could not be createdFlushMode.MANUAL
protected String getParticipateAttributeName()
The default implementation takes the toString()
representation
of the SessionFactory
instance and appends PARTICIPATE_SUFFIX
.
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |