| |||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
ArrayList rdns = …;
int i = …;
Based on 9 examples
Attributes attrs = …;
Based on 9 examples
String str = …;
Based on 8 examples
public class Rdn extends Object implements Serializable, Comparable
This class represents a relative distinguished name, or RDN, which is a component of a distinguished name as specified by RFC 2253. An example of an RDN is "OU=Sales+CN=J.Smith". In this example, the RDN consist of multiple attribute type/value pairs. The RDN is parsed as described in the class description for {@link javax.naming.ldap.LdapName LdapName}.
The Rdn class represents an RDN as attribute type/value mappings, which can be viewed using {@link javax.naming.directory.Attributes 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 {@link #unescapeValue(String) unescapeValue()} method can be used to unescape the escaped comma resulting in the original value "Juicy, Fruit". The {@link #escapeValue(Object) 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.
Constructor Summary | |
---|---|
Rdn(Attributes attrSet) Constructs an Rdn from the given attribute set. |
|
Constructs an Rdn from the given rdn. |
|
Constructs an Rdn from the given string. |
|
Constructs an Rdn from the given attribute type and value. |
Method Summary | |
---|---|
int |
Compares this Rdn with the specified Object for order. |
boolean |
Compares the specified Object with this Rdn for equality. |
static String |
escapeValue(Object val) Given the value of an attribute, returns a string escaped according to the rules specified in RFC 2253. |
String |
getType() Retrieves one of this Rdn's type. |
Object |
getValue() Retrieves one of this Rdn's value. |
int |
hashCode() Returns the hash code of this RDN. |
int |
size() Retrieves the number of attribute type/value pairs in this Rdn. |
Attributes |
Retrieves the javax.naming.directory.Attributes view of the type/value mappings contained in this Rdn. |
String |
toString() Returns this Rdn as a string represented in a format defined by RFC 2253 and described in the class description for javax.naming.ldap.LdapName. |
static Object |
unescapeValue(String val) Given an attribute value string formated according to the rules specified in RFC 2253, returns the unformated value. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Constructor Detail |
---|
public Rdn(Attributes attrSet) throws InvalidNameException
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.
attrSet
- The non-null and non-empty attributes containing
type/value mappings.InvalidNameException
- If contents of attrSet cannot
be used to construct a valid RDN.public Rdn(Rdn rdn)
rdn
- The non-null Rdn to be copied.public Rdn(String rdnString) throws InvalidNameException
rdnString
- The non-null and non-empty RFC2253 formatted string.InvalidNameException
- If a syntax error occurs during
parsing of the rdnString.public Rdn(String type, Object value) throws InvalidNameException
type
- The non-null and non-empty string attribute type.value
- The non-null and non-empty attribute value.InvalidNameException
- If type/value cannot be used to
construct a valid RDN.Method Detail |
---|
public int compareTo(Object obj)
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.
obj
- The non-null object to compare against.public boolean equals(Object obj)
Type and value equalilty matching is done as below:
If obj is null or not an instance of Rdn, false is returned.
equals
in class Object
obj
- object to be compared for equality with this Rdn.public static String escapeValue(Object val)
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.
val
- The non-null object to be escaped.public String getType()
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 {@link #getValue() getValue()} method returns the value corresponding to the type returned by this method.
public Object getValue()
For a multi-valued RDN, this method returns value corresponding to the type returned by {@link #getType() getType()} method.
public int hashCode()
hashCode
in class Object
public int size()
public Attributes toAttributes()
public String toString()
toString
in class Object
public static Object unescapeValue(String val)
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.
val
- The non-null string to be unescaped.
| |||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |