|
JavaTM 2 Platform Std. Ed. v1.4.2 |
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object java.lang.Throwable java.lang.Exception javax.naming.NamingException javax.naming.ReferralException
This abstract class is used to represent a referral exception, which is generated in response to a referral such as that returned by LDAP v3 servers.
A service provider provides a subclass of ReferralException by providing implementations for getReferralInfo() and getReferralContext() (and appropriate constructors and/or corresponding "set" methods).
The following code sample shows how ReferralException can be used.
while (true) { try { bindings = ctx.listBindings(name); while (bindings.hasMore()) { b = bindings.next(); ... } break; } catch (ReferralException e) { ctx = e.getReferralContext(); } }
ReferralException is an abstract class. Concrete implementations determine its synchronization and serialization properties.
An environment parameter passed to the getReferralContext() method is owned by the caller. The service provider will not modify the object or keep a reference to it, but may keep a reference to a clone of it.
Field Summary |
Fields inherited from class javax.naming.NamingException |
remainingName, resolvedName, resolvedObj, rootException |
Constructor Summary | |
protected |
ReferralException()
Constructs a new instance of ReferralException. |
protected |
ReferralException(String explanation)
Constructs a new instance of ReferralException using the explanation supplied. |
Method Summary | |
abstract Context |
getReferralContext()
Retrieves the context at which to continue the method. |
abstract Context |
getReferralContext(Hashtable env)
Retrieves the context at which to continue the method using environment properties. |
abstract Object |
getReferralInfo()
Retrieves information (such as URLs) related to this referral. |
abstract void |
retryReferral()
Retries the referral currently being processed. |
abstract boolean |
skipReferral()
Discards the referral about to be processed. |
Methods inherited from class javax.naming.NamingException |
appendRemainingComponent, appendRemainingName, getCause, getExplanation, getRemainingName, getResolvedName, getResolvedObj, getRootCause, initCause, setRemainingName, setResolvedName, setResolvedObj, setRootCause, toString, toString |
Methods inherited from class java.lang.Throwable |
fillInStackTrace, getLocalizedMessage, getMessage, getStackTrace, printStackTrace, printStackTrace, printStackTrace, setStackTrace |
Methods inherited from class java.lang.Object |
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Constructor Detail |
protected ReferralException(String explanation)
explanation
- Additional detail about this exception. Can be null.Throwable.getMessage()
protected ReferralException()
Method Detail |
public abstract Object getReferralInfo()
public abstract Context getReferralContext() throws NamingException
To continue the operation, the client program should re-invoke the method using the same arguments as the original invocation.
NamingException
- If a naming exception was encountered.
Call either retryReferral() or skipReferral()
to continue processing referrals.public abstract Context getReferralContext(Hashtable env) throws NamingException
The referral context is created using env as its environment properties. This method should be used instead of the no-arg overloaded form when the caller needs to use different environment properties for the referral context. It might need to do this, for example, when it needs to supply different authentication information to the referred server in order to create the referral context.
To continue the operation, the client program should re-invoke the method using the same arguments as the original invocation.
env
- The possibly null environment to use when retrieving the
referral context. If null, no environment properties will be used.
NamingException
- If a naming exception was encountered.
Call either retryReferral() or skipReferral()
to continue processing referrals.public abstract boolean skipReferral()
getReferralContext
to allow the processing of
other referrals to continue.
The following code fragment shows a typical usage pattern.
} catch (ReferralException e) { if (!shallIFollow(e.getReferralInfo())) { if (!e.skipReferral()) { return; } } ctx = e.getReferralContext(); }
public abstract void retryReferral()
getReferralContext
to allow the current
referral to be retried.
The following code fragment shows a typical usage pattern.
} catch (ReferralException e) { while (true) { try { ctx = e.getReferralContext(env); break; } catch (NamingException ne) { if (! shallIRetry()) { return; } // modify environment properties (env), if necessary e.retryReferral(); } } }
|
JavaTM 2 Platform Std. Ed. v1.4.2 |
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
Copyright © 2003, 2010 Oracle and/or its affiliates. All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.