|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Objectorg.springframework.jndi.JndiAccessor
org.springframework.jndi.JndiLocatorSupport
org.springframework.jndi.JndiObjectLocator
org.springframework.ejb.access.AbstractSlsbInvokerInterceptor
public abstract class AbstractSlsbInvokerInterceptor
Base class for AOP interceptors invoking local or remote Stateless Session Beans. Designed for EJB 2.x, but works for EJB 3 Session Beans as well.
Such an interceptor must be the last interceptor in the advice chain. In this case, there is no direct target object: The call is handled in a special way, getting executed on an EJB instance retrieved via an EJB home.
Field Summary |
---|
Fields inherited from class org.springframework.jndi.JndiLocatorSupport |
---|
CONTAINER_PREFIX |
Fields inherited from class org.springframework.jndi.JndiAccessor |
---|
logger |
Constructor Summary | |
---|---|
AbstractSlsbInvokerInterceptor()
|
Method Summary | |
---|---|
void |
afterPropertiesSet()
Fetches EJB home on startup, if necessary. |
protected java.lang.Object |
create()
Invokes the create() method on the cached EJB home object. |
protected java.lang.reflect.Method |
getCreateMethod(java.lang.Object home)
Determine the create method of the given EJB home object. |
protected java.lang.Object |
getHome()
Return the EJB home object to use. |
java.lang.Object |
invoke(org.aopalliance.intercept.MethodInvocation invocation)
Prepares the thread context if necessar, and delegates to invokeInContext(org.aopalliance.intercept.MethodInvocation) . |
protected abstract java.lang.Object |
invokeInContext(org.aopalliance.intercept.MethodInvocation invocation)
Perform the given invocation on the current EJB home, within the thread context being prepared accordingly. |
protected boolean |
isHomeRefreshable()
Return whether the cached EJB home object is potentially subject to on-demand refreshing. |
protected void |
refreshHome()
Refresh the cached home object, if applicable. |
void |
setCacheHome(boolean cacheHome)
Set whether to cache the EJB home object once it has been located. |
void |
setExposeAccessContext(boolean exposeAccessContext)
Set whether to expose the JNDI environment context for all access to the target EJB, i.e. for all method invocations on the exposed object reference. |
void |
setLookupHomeOnStartup(boolean lookupHomeOnStartup)
Set whether to look up the EJB home object on startup. |
Methods inherited from class org.springframework.jndi.JndiObjectLocator |
---|
getExpectedType, getJndiName, lookup, setExpectedType, setJndiName |
Methods inherited from class org.springframework.jndi.JndiLocatorSupport |
---|
convertJndiName, isResourceRef, lookup, lookup, setResourceRef |
Methods inherited from class org.springframework.jndi.JndiAccessor |
---|
getJndiEnvironment, getJndiTemplate, setJndiEnvironment, setJndiTemplate |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public AbstractSlsbInvokerInterceptor()
Method Detail |
---|
public void setLookupHomeOnStartup(boolean lookupHomeOnStartup)
Can be turned off to allow for late start of the EJB server. In this case, the EJB home object will be fetched on first access.
setCacheHome(boolean)
public void setCacheHome(boolean cacheHome)
Can be turned off to allow for hot restart of the EJB server. In this case, the EJB home object will be fetched for each invocation.
setLookupHomeOnStartup(boolean)
public void setExposeAccessContext(boolean exposeAccessContext)
Default is "false", i.e. to only expose the JNDI context for object lookup. Switch this flag to "true" in order to expose the JNDI environment (including the authorization context) for each EJB invocation, as needed by WebLogic for EJBs with authorization requirements.
public void afterPropertiesSet() throws javax.naming.NamingException
afterPropertiesSet
in interface InitializingBean
afterPropertiesSet
in class JndiObjectLocator
javax.naming.NamingException
setLookupHomeOnStartup(boolean)
,
refreshHome()
protected void refreshHome() throws javax.naming.NamingException
javax.naming.NamingException
- if thrown by the JNDI lookupJndiObjectLocator.lookup()
,
getCreateMethod(java.lang.Object)
protected java.lang.reflect.Method getCreateMethod(java.lang.Object home) throws EjbAccessException
home
- the EJB home object
EjbAccessException
- if the method couldn't be retrievedprotected java.lang.Object getHome() throws javax.naming.NamingException
Default implementation returns the home created on initialization, if any; else, it invokes lookup to get a new proxy for each invocation.
Can be overridden in subclasses, for example to cache a home object for a given amount of time before recreating it, or to test the home object whether it is still alive.
javax.naming.NamingException
- if proxy creation failedJndiObjectLocator.lookup()
,
getCreateMethod(java.lang.Object)
protected boolean isHomeRefreshable()
public java.lang.Object invoke(org.aopalliance.intercept.MethodInvocation invocation) throws java.lang.Throwable
invokeInContext(org.aopalliance.intercept.MethodInvocation)
.
invoke
in interface org.aopalliance.intercept.MethodInterceptor
java.lang.Throwable
protected abstract java.lang.Object invokeInContext(org.aopalliance.intercept.MethodInvocation invocation) throws java.lang.Throwable
invocation
- the AOP method invocation
java.lang.Throwable
- in case of invocation failureprotected java.lang.Object create() throws javax.naming.NamingException, java.lang.reflect.InvocationTargetException
create()
method on the cached EJB home object.
javax.naming.NamingException
- if thrown by JNDI
java.lang.reflect.InvocationTargetException
- if thrown by the create method
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |