| public class javax.naming.ldap Rdn
|
Java SE 6 |
LdapName.
The Rdn class represents an RDN as attribute type/value mappings,
which can be viewed using
Attributes.
In addition, it contains convenience methods that allow easy retrieval
of type and value when the Rdn consist of a single type/value pair,
which is how it appears in a typical usage.
It also contains helper methods that allow escaping of the unformatted
attribute value and unescaping of the value formatted according to the
escaping syntax defined in RFC2253. For methods that take or return
attribute value as an Object, the value is either a String
(in unescaped form) or a byte array.
Rdn will properly parse all valid RDNs, but
does not attempt to detect all possible violations when parsing
invalid RDNs. It is "generous" in accepting invalid RDNs.
The "validity" of a name is determined ultimately when it
is supplied to an LDAP server, which may accept or
reject the name based on factors such as its schema information
and interoperability considerations.
The following code example shows how to construct an Rdn using the constructor that takes type and value as arguments:
Rdn rdn = new Rdn("cn", "Juicy, Fruit");
System.out.println(rdn.toString());
The last line will print cn=Juicy\, Fruit. The
unescapeValue() method can be
used to unescape the escaped comma resulting in the original
value "Juicy, Fruit". The escapeValue() method adds the escape back preceding the comma.
This class can be instantiated by a string representation of the RDN defined in RFC 2253 as shown in the following code example:
Rdn rdn = new Rdn("cn=Juicy\\, Fruit");
System.out.println(rdn.toString());
The last line will print cn=Juicy\, Fruit.
Concurrent multithreaded read-only access of an instance of Rdn need not be synchronized.
Unless otherwise noted, the behavior of passing a null argument to a constructor or method in this class will cause NullPointerException to be thrown.
| version | 1.9 05/11/17 |
| since | 1.5 |
| Constructors | |||||||||
|---|---|---|---|---|---|---|---|---|---|
| public | Rdn(Attributes attrSet) throws InvalidNameException Constructs an Rdn from the given attribute set. See Attributes.
The string attribute values are not interpretted as RFC 2253 formatted RDN strings. That is, the values are used literally (not parsed) and assumed to be unescaped.
| ||||||||
| public | Rdn(String rdnString) throws InvalidNameException Constructs an Rdn from the given string. This constructor takes a string formatted according to the rules defined in RFC 2253 and described in the class description for javax.naming.ldap.LdapName.
| ||||||||
| public | Rdn(Rdn rdn) Constructs an Rdn from the given rdn. The contents of the rdn are simply copied into the newly created Rdn.
| ||||||||
| public | Rdn(String type, Object value) throws InvalidNameException Constructs an Rdn from the given attribute type and value. The string attribute values are not interpretted as RFC 2253 formatted RDN strings. That is, the values are used literally (not parsed) and assumed to be unescaped.
| ||||||||
| Methods | |||||||
|---|---|---|---|---|---|---|---|
| public int | compareTo(Object obj) Compares this Rdn with the specified Object for order. Returns a negative integer, zero, or a positive integer as this Rdn is less than, equal to, or greater than the given Object. If obj is null or not an instance of Rdn, ClassCastException is thrown. The attribute type and value pairs of the RDNs are lined up against each other and compared lexicographically. The order of components in multi-valued Rdns (such as "ou=Sales+cn=Bob") is not significant.
| ||||||
| public boolean | equals(Object obj) Compares the specified Object with this Rdn for equality. Returns true if the given object is also a Rdn and the two Rdns represent the same attribute type and value mappings. The order of components in multi-valued Rdns (such as "ou=Sales+cn=Bob") is not significant. Type and value equalilty matching is done as below:
If obj is null or not an instance of Rdn, false is returned.
| ||||||
| public static String | escapeValue(Object val) Given the value of an attribute, returns a string escaped according to the rules specified in RFC 2253. For example, if the val is "Sue, Grabbit and Runn", the escaped value returned by this method is "Sue\, Grabbit and Runn". A string value is represented as a String and binary value as a byte array.
| ||||||
| public int | hashCode() Returns the hash code of this RDN. Two RDNs that are equal (according to the equals method) will have the same hash code.
| ||||||
| public int | size() Retrieves the number of attribute type/value pairs in this Rdn.
| ||||||
| public Attributes | toAttributes() Retrieves the Attributes
view of the type/value mappings contained in this Rdn.
| ||||||
| public String | toString() Returns this Rdn as a string represented in a format defined by RFC 2253 and described in the class description for LdapName.
| ||||||
| public static Object | unescapeValue(String val) Given an attribute value string formated according to the rules specified in RFC 2253, returns the unformated value. Escapes and quotes are stripped away, and hex-encoded UTF-8 is converted to equivalent UTF-16 characters. Returns a string value as a String, and a binary value as a byte array. Legal and illegal values are defined in RFC 2253. This method is generous in accepting the values and does not catch all illegal values. Therefore, passing in an illegal value might not necessarily trigger an IllegalArgumentException.
| ||||||
| Properties | |||
|---|---|---|---|
| public String | getType() Retrieves one of this Rdn's type. This is a convenience method for obtaining the type, when the RDN contains a single type and value mapping, which is the common RDN usage.
For a multi-valued RDN, the type/value pairs have
no specific order defined on them. In that case, this method
returns type of one of the type/value pairs.
The
| ||
| public Object | getValue() Retrieves one of this Rdn's value. This is a convenience method for obtaining the value, when the RDN contains a single type and value mapping, which is the common RDN usage.
For a multi-valued RDN, this method returns value corresponding
to the type returned by
| ||
| About DocWeb · Bundles · Export · Export All | Top 10 · Statistics · Login |
| About Sun · Contact · Privacy · Terms of Use · Trademarks | Java SE 6 · Copyright © 1994-2009 Sun Microsystems, Inc.All rights reserved. Use is subject to license terms |
![]() |
![]() |
|