org.springframework.jndi
Class JndiObjectLocator

java.lang.Object
  extended by org.springframework.jndi.JndiAccessor
      extended by org.springframework.jndi.JndiLocatorSupport
          extended by org.springframework.jndi.JndiObjectLocator
All Implemented Interfaces:
InitializingBean
Direct Known Subclasses:
AbstractSlsbInvokerInterceptor, JndiObjectFactoryBean, JndiObjectTargetSource, JndiRmiClientInterceptor

public abstract class JndiObjectLocator
extends JndiLocatorSupport
implements InitializingBean

Convenient superclass for JNDI-based service locators. Subclasses are JavaBeans, exposing a "jndiName" property. This may or may not include the "java:comp/env/" prefix expected by J2EE applications when accessing a locally mapped (ENC - Environmental Naming Context) resource. If it doesn't, the "java:comp/env/" prefix will be prepended if the "resourceRef" property is true (the default is false) and no other scheme like "java:" is given.

Subclasses can invoke the lookup method whenever it is appropriate. Some classes might do this on initialization, while others might do it on demand. The latter strategy is more flexible in that it allows for initialization of the locator before the JNDI object is available.

Author:
Juergen Hoeller
See Also:
setJndiName(java.lang.String), JndiAccessor.setJndiTemplate(org.springframework.jndi.JndiTemplate), JndiAccessor.setJndiEnvironment(java.util.Properties), JndiLocatorSupport.setResourceRef(boolean), lookup()

Field Summary
 
Fields inherited from class org.springframework.jndi.JndiLocatorSupport
CONTAINER_PREFIX
 
Fields inherited from class org.springframework.jndi.JndiAccessor
logger
 
Constructor Summary
JndiObjectLocator()
           
 
Method Summary
 void afterPropertiesSet()
          Check the "jndiName" property.
 Class getExpectedType()
          Return the type that the located JNDI object is supposed to be assignable to, if any.
 String getJndiName()
          Return the JNDI name to look up.
protected  Object lookup()
          Perform the actual JNDI lookup via the JndiTemplate.
 void setExpectedType(Class expectedType)
          Set the type that the located JNDI object is supposed to be assignable to, if any.
 void setJndiName(String jndiName)
          Set the JNDI name to look up.
 
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

JndiObjectLocator

public JndiObjectLocator()
Method Detail

setJndiName

public void setJndiName(String jndiName)
Set the JNDI name to look up. If it doesn't begin with "java:comp/env/" this prefix is added if resourceRef is set to true.

Parameters:
jndiName - JNDI name to look up
See Also:
JndiLocatorSupport.setResourceRef(boolean)

getJndiName

public String getJndiName()
Return the JNDI name to look up.


setExpectedType

public void setExpectedType(Class expectedType)
Set the type that the located JNDI object is supposed to be assignable to, if any.


getExpectedType

public Class getExpectedType()
Return the type that the located JNDI object is supposed to be assignable to, if any.


afterPropertiesSet

public void afterPropertiesSet()
                        throws NamingException
Check the "jndiName" property.

Specified by:
afterPropertiesSet in interface InitializingBean
Throws:
NamingException

lookup

protected Object lookup()
                 throws NamingException
Perform the actual JNDI lookup via the JndiTemplate. Invokes the located method after successful lookup.

Throws:
NamingException - if the JNDI lookup failed or if the located JNDI object is not assigable to the expected type
See Also:
setJndiName(java.lang.String), setExpectedType(java.lang.Class)


Copyright (c) 2002-2006 The Spring Framework Project.