Class LdapDnsProvider
public abstract class LdapDnsProvider extends Object
An LDAP DNS provider is a concrete subclass of this class that has a zero-argument constructor. LDAP DNS providers are located using the ServiceLoader facility, as specified by InitialDirectContext. The ServiceLoader
is used to create and register implementations of LdapDnsProvider
.
An LDAP DNS provider can be used in environments where the default DNS resolution mechanism is not sufficient to accurately pinpoint the correct LDAP servers needed to perform LDAP operations. For example, in an environment containing a mix of ldap
and ldaps
servers you may want the LdapContext to query ldaps
servers only.
- Since:
- 12
Constructor Summary
Modifier | Constructor | Description |
---|---|---|
protected |
Creates a new instance of LdapDnsProvider . |
Method Summary
Modifier and Type | Method | Description |
---|---|---|
abstract Optional<LdapDnsProviderResult> |
lookupEndpoints |
Lookup the endpoints and domain name for the given Context provider URL and environment. |
Constructor Details
LdapDnsProvider
protected LdapDnsProvider()
LdapDnsProvider
.- Throws:
-
SecurityException
- if a security manager is present and itscheckPermission
method doesn't allow theRuntimePermission("ldapDnsProvider")
.
Method Details
lookupEndpoints
public abstract Optional<LdapDnsProviderResult> lookupEndpoints(String url, Map<?,?> env) throws NamingException
Context
provider URL
and environment. The resolved endpoints and domain name are returned as an LdapDnsProviderResult
. An endpoint is a String
representation of an LDAP URL which points to an LDAP server to be used for LDAP operations. The syntax of an LDAP URL is defined by RFC 2255: The LDAP URL Format.
- Parameters:
-
url
- TheContext
provider URL
-
env
- TheContext
environment. - Returns:
- an
LdapDnsProviderResult
or emptyOptional
if the lookup fails. - Throws:
-
NamingException
- if theurl
is not valid or an error occurred while performing the lookup. -
NullPointerException
- if eitherurl
orenv
arenull
.
© 1993, 2021, Oracle and/or its affiliates. All rights reserved.
Documentation extracted from Debian's OpenJDK Development Kit package.
Licensed under the GNU General Public License, version 2, with the Classpath Exception.
Various third party code in OpenJDK is licensed under different licenses (see Debian package).
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
https://docs.oracle.com/en/java/javase/17/docs/api/java.naming/javax/naming/ldap/spi/LdapDnsProvider.html