LdapReferralException (Java SE 15 & JDK 15) (original) (raw)
All Implemented Interfaces:
[Serializable](../../../../java.base/java/io/Serializable.html "interface in java.io")
public abstract class LdapReferralException extends ReferralException
This abstract class is used to represent an LDAP referral exception. It extends the base ReferralException
by providing agetReferralContext()
method that accepts request controls. LdapReferralException is an abstract class. Concrete implementations of it determine its synchronization and serialization properties.
A Control[]
array passed as a parameter to the getReferralContext()
method is owned by the caller. The service provider will not modify the array or keep a reference to it, although it may keep references to the individual Control
objects in the array.
Since:
1.3
See Also:
Field Summary
Constructor Summary
Constructors
Modifier | Constructor | Description |
---|---|---|
protected | LdapReferralException() | Constructs a new instance of LdapReferralException. |
protected | LdapReferralException(String explanation) | Constructs a new instance of LdapReferralException using the explanation supplied. |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
abstract Context | getReferralContext() | Retrieves the context at which to continue the method using the context's environment and no controls. |
abstract Context | getReferralContext(Hashtable env) | Retrieves the context at which to continue the method using environment properties and no controls. |
abstract Context | getReferralContext(Hashtable env,Control[] reqCtls) | Retrieves the context at which to continue the method using request controls and environment properties. |
Methods declared in class javax.naming.NamingException
[appendRemainingComponent](../NamingException.html#appendRemainingComponent%28java.lang.String%29), [appendRemainingName](../NamingException.html#appendRemainingName%28javax.naming.Name%29), [getCause](../NamingException.html#getCause%28%29), [getExplanation](../NamingException.html#getExplanation%28%29), [getRemainingName](../NamingException.html#getRemainingName%28%29), [getResolvedName](../NamingException.html#getResolvedName%28%29), [getResolvedObj](../NamingException.html#getResolvedObj%28%29), [getRootCause](../NamingException.html#getRootCause%28%29), [initCause](../NamingException.html#initCause%28java.lang.Throwable%29), [setRemainingName](../NamingException.html#setRemainingName%28javax.naming.Name%29), [setResolvedName](../NamingException.html#setResolvedName%28javax.naming.Name%29), [setResolvedObj](../NamingException.html#setResolvedObj%28java.lang.Object%29), [setRootCause](../NamingException.html#setRootCause%28java.lang.Throwable%29), [toString](../NamingException.html#toString%28%29), [toString](../NamingException.html#toString%28boolean%29)
Constructor Details
LdapReferralException
protected LdapReferralException(String explanation)
Constructs a new instance of LdapReferralException using the explanation supplied. All other fields are set to null.
Parameters:
explanation
- Additional detail about this exception. Can be null.
See Also:
Throwable.getMessage()LdapReferralException
protected LdapReferralException()
Constructs a new instance of LdapReferralException. All fields are set to null.Method Details
getReferralContext
Retrieves the context at which to continue the method using the context's environment and no controls. The referral context is created using the environment properties of the context that threw the
ReferralException
and no controls.
This method is equivalent togetReferralContext(ctx.getEnvironment(), null);
wherectx
is the context that threw theReferralException.
It is overridden in this class for documentation purposes only. SeeReferralException
for how to use this method.
Specified by:
[getReferralContext](../ReferralException.html#getReferralContext%28%29)
in class[ReferralException](../ReferralException.html "class in javax.naming")
Returns:
The non-null context at which to continue the method.
Throws:
[NamingException](../NamingException.html "class in javax.naming")
- If a naming exception was encountered. Call eitherretryReferral()
orskipReferral()
to continue processing referrals.getReferralContext
Retrieves the context at which to continue the method using environment properties and no controls. The referral context is created using
env
as its environment properties and no controls.
This method is equivalent togetReferralContext(env, null);
It is overridden in this class for documentation purposes only. SeeReferralException
for how to use this method.
Specified by:
[getReferralContext](../ReferralException.html#getReferralContext%28java.util.Hashtable%29)
in class[ReferralException](../ReferralException.html "class in javax.naming")
Parameters:
env
- The possibly null environment to use when retrieving the referral context. If null, no environment properties will be used.
Returns:
The non-null context at which to continue the method.
Throws:
[NamingException](../NamingException.html "class in javax.naming")
- If a naming exception was encountered. Call eitherretryReferral()
orskipReferral()
to continue processing referrals.getReferralContext
Retrieves the context at which to continue the method using request controls and environment properties. Regardless of whether a referral is encountered directly during a context operation, or indirectly, for example, during a search enumeration, the referral exception should provide a context at which to continue the operation. To continue the operation, the client program should re-invoke the method using the same arguments as the original invocation.
reqCtls
is used when creating the connection to the referred server. These controls will be used as the connection request controls for the context and context instances derived from the context.reqCtls
will also be the context's request controls for subsequent context operations. See theLdapContext
class description for details.
This method should be used instead of the other two overloaded forms when the caller needs to supply request controls for creating the referral context. It might need to do this, for example, when it needs to supply special controls relating to authentication.
Service provider implementors should read the "Service Provider" section in theLdapContext
class description for implementation details.
Parameters:
reqCtls
- The possibly null request controls to use for the new context. If null or the empty array means use no request controls.
env
- The possibly null environment properties to use when for the new context. If null, the context is initialized with no environment properties.
Returns:
The non-null context at which to continue the method.
Throws:
[NamingException](../NamingException.html "class in javax.naming")
- If a naming exception was encountered. Call eitherretryReferral()
orskipReferral()
to continue processing referrals.