public final class KerberosPrincipal extends Object implements Principal, Serializable
| Modifier and Type | Field and Description | 
|---|---|
| static int | KRB_NT_PRINCIPALuser principal name type. | 
| static int | KRB_NT_SRV_HSTservice with host name as instance (telnet, rcommands) name type. | 
| static int | KRB_NT_SRV_INSTservice and other unique instance (krbtgt) name type. | 
| static int | KRB_NT_SRV_XHSTservice with host as remaining components name type. | 
| static int | KRB_NT_UIDunique ID name type. | 
| static int | KRB_NT_UNKNOWNunknown name type. | 
| Constructor and Description | 
|---|
| KerberosPrincipal(String name)Constructs a KerberosPrincipal from the provided string input. | 
| KerberosPrincipal(String name,
                 int nameType)Constructs a KerberosPrincipal from the provided string and
 name type input. | 
| Modifier and Type | Method and Description | 
|---|---|
| boolean | equals(Object other)Compares the specified Object with this Principal for equality. | 
| String | getName()The returned string corresponds to the single-string
 representation of a Kerberos Principal name as specified in
 Section 2.1 of RFC 1964. | 
| int | getNameType()Returns the name type of the KerberosPrincipal. | 
| String | getRealm()Returns the realm component of this Kerberos principal. | 
| int | hashCode()Returns a hashcode for this principal. | 
| String | toString()Returns a string representation of the object. | 
public static final int KRB_NT_UNKNOWN
public static final int KRB_NT_PRINCIPAL
public static final int KRB_NT_SRV_INST
public static final int KRB_NT_SRV_HST
public static final int KRB_NT_SRV_XHST
public static final int KRB_NT_UID
public KerberosPrincipal(String name)
KRB_NT_PRINCIPAL
 This string is assumed to contain a name in the format
 that is specified in Section 2.1.1. (Kerberos Principal Name Form) of
  RFC 1964 
 (for example, duke@FOO.COM, where duke
 represents a principal, and FOO.COM represents a realm).
 If the input name does not contain a realm, the default realm is used. The default realm can be specified either in a Kerberos configuration file or via the java.security.krb5.realm system property. For more information, Kerberos Requirements
name - the principal nameIllegalArgumentException - if name is improperly
 formatted, if name is null, or if name does not contain
 the realm to use and the default realm is not specified
 in either a Kerberos configuration file or via the
 java.security.krb5.realm system property.public KerberosPrincipal(String name, int nameType)
If the input name does not contain a realm, the default realm is used. The default realm can be specified either in a Kerberos configuration file or via the java.security.krb5.realm system property. For more information, see Kerberos Requirements.
name - the principal namenameType - the name type of the principalIllegalArgumentException - if name is improperly
 formatted, if name is null, if the nameType is not supported,
 or if name does not contain the realm to use and the default
 realm is not specified in either a Kerberos configuration
 file or via the java.security.krb5.realm system property.public String getRealm()
public int hashCode()
  hashCode = getName().hashCode();
 hashCode in interface PrincipalhashCode in class ObjectKerberosPrincipalObject.equals(java.lang.Object), 
System.identityHashCode(java.lang.Object)public boolean equals(Object other)
KerberosPrincipal and the two
 KerberosPrincipal instances are equivalent.
 More formally two KerberosPrincipal instances are equal
 if the values returned by getName() are equal.public String getName()
public int getNameType()
public String toString()
ObjecttoString method returns a string that
 "textually represents" this object. The result should
 be a concise but informative representation that is easy for a
 person to read.
 It is recommended that all subclasses override this method.
 
 The toString method for class Object
 returns a string consisting of the name of the class of which the
 object is an instance, the at-sign character `@', and
 the unsigned hexadecimal representation of the hash code of the
 object. In other words, this method returns a string equal to the
 value of:
 
getClass().getName() + '@' + Integer.toHexString(hashCode())
 Submit a bug or feature 
For further API reference and developer documentation, see Java SE Documentation. That documentation contains more detailed, developer-targeted descriptions, with conceptual overviews, definitions of terms, workarounds, and working code examples.
 Copyright © 1993, 2025, Oracle and/or its affiliates.  All rights reserved. Use is subject to license terms. Also see the documentation redistribution policy.