Abstract class for X.509 certificates. This provides a standard way to access all the attributes of an X.509 certificate.
In June of 1996, the basic X.509 v3 format was completed by ISO/IEC and ANSI X9, which is described below in ASN.1:
Certificate ::= SEQUENCE { tbsCertificate TBSCertificate, signatureAlgorithm AlgorithmIdentifier, signature BIT STRING }
These certificates are widely used to support authentication and other functionality in Internet security systems. Common applications include Privacy Enhanced Mail (PEM), Transport Layer Security (SSL), code signing for trusted software distribution, and Secure Electronic Transactions (SET).
These certificates are managed and vouched for by Certificate Authorities (CAs). CAs are services which create certificates by placing data in the X.509 standard format and then digitally signing that data. CAs act as trusted third parties, making introductions between principals who have no direct knowledge of each other. CA certificates are either signed by themselves, or by some other CA such as a "root" CA.
More information can be found in RFC 5280: Internet X.509 Public Key Infrastructure Certificate and CRL Profile.
The ASN.1 definition of tbsCertificate
is:
TBSCertificate ::= SEQUENCE { version [0] EXPLICIT Version DEFAULT v1, serialNumber CertificateSerialNumber, signature AlgorithmIdentifier, issuer Name, validity Validity, subject Name, subjectPublicKeyInfo SubjectPublicKeyInfo, issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL, -- If present, version must be v2 or v3 subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL, -- If present, version must be v2 or v3 extensions [3] EXPLICIT Extensions OPTIONAL -- If present, version must be v3 }
Certificates are instantiated using a certificate factory. The following is an example of how to instantiate an X.509 certificate:
try (InputStream inStream = new FileInputStream("fileName-of-cert")) { CertificateFactory cf = CertificateFactory.getInstance("X.509"); X509Certificate cert = (X509Certificate)cf.generateCertificate(inStream); }
Certificate
, CertificateFactory
, X509Extension
Modifier and Type | Field and Description |
---|---|
private transient X500Principal | |
private static final long | |
private transient X500Principal |
Access | Constructor and Description |
---|---|
protected |
Modifier and Type | Method and Description |
---|---|
public abstract void | |
public abstract void | checkValidity(Date
the Date to check against to see if this certificate
is valid at that date/time. date)Checks that the given date is within the certificate's validity period. |
public abstract int | Returns: the value ofpathLenConstraint if the
BasicConstraints extension is present in the certificate and the
subject of the certificate is a CA, otherwise -1.
If the subject of the certificate is a CA and
pathLenConstraint does not appear,
Integer.MAX_VALUE is returned to indicate that there is no
limit to the allowed length of the certification path.Gets the certificate constraints path length from the
critical |
public List | Returns: the ExtendedKeyUsage extension of this certificate, as an unmodifiable list of object identifiers represented as Strings. Returns null if this certificate does not contain an ExtendedKeyUsage extension.Gets an unmodifiable list of Strings representing the OBJECT
IDENTIFIERs of the |
public Collection | Returns: an immutableCollection of issuer alternative
names (or null )Gets an immutable collection of issuer alternative names from the
|
public abstract Principal | Returns: a Principal whose name is the issuer distinguished name.
Deprecated
since 16. Use
getIssuerX500Principal instead.
Gets the |
public abstract boolean[] | Returns: the issuer unique identifier or null if it is not present in the certificate.Gets the |
public X500Principal | Returns: anX500Principal representing the issuer
distinguished nameReturns the issuer (issuer distinguished name) value from the
certificate as an |
public abstract boolean[] | Returns: the KeyUsage extension of this certificate, represented as an array of booleans. The order of KeyUsage values in the array is the same as in the above ASN.1 definition. The array will contain a value for each KeyUsage defined above. If the KeyUsage list encoded in the certificate is longer than the above list, it will not be truncated. Returns null if this certificate does not contain a KeyUsage extension.Gets a boolean array representing bits of
the |
public abstract Date | Returns: the end date of the validity period.Gets the |
public abstract Date | Returns: the start date of the validity period.Gets the |
public abstract BigInteger | |
public abstract String | Returns: the signature algorithm name.Gets the signature algorithm name for the certificate signature algorithm. |
public abstract String | Returns: the signature algorithm OID string.Gets the signature algorithm OID string from the certificate. |
public abstract byte[] | Returns: the DER-encoded signature algorithm parameters, or null if no parameters are present.Gets the DER-encoded signature algorithm parameters from this certificate's signature algorithm. |
public abstract byte[] | Returns: the signature.Gets the |
public Collection | Returns: an immutableCollection of subject alternative
names (or null )Gets an immutable collection of subject alternative names from the
|
public abstract Principal | Returns: a Principal whose name is the subject name.
Deprecated
since 16. Use
getSubjectX500Principal instead.
Gets the |
public abstract boolean[] | Returns: the subject unique identifier or null if it is not present in the certificate.Gets the |
public X500Principal | Returns: anX500Principal representing the subject
distinguished nameReturns the subject (subject distinguished name) value from the
certificate as an |
public abstract byte[] | Returns: the DER-encoded certificate information.Gets the DER-encoded certificate information, the
|
public abstract int | Returns: the version number, i.e. 1, 2 or 3.Gets the |
public void | verify(PublicKey
the PublicKey used to carry out the verification. key, Provider the signature provider. sigProvider)Overrides java. Verifies that this certificate was signed using the private key that corresponds to the specified public key. |
issuerX500Principal | back to summary |
---|---|
private transient X500Principal issuerX500Principal |
serialVersionUID | back to summary |
---|---|
private static final long serialVersionUID Hides java. |
subjectX500Principal | back to summary |
---|---|
private transient X500Principal subjectX500Principal |
X509Certificate | back to summary |
---|---|
protected X509Certificate() Constructor for X.509 certificates. |
checkValidity | back to summary |
---|---|
public abstract void checkValidity() throws CertificateExpiredException, CertificateNotYetValidException Checks that the certificate is currently valid. It is if the current date and time are within the validity period given in the certificate. The validity period consists of two date/time values: the first and last dates (and times) on which the certificate is valid. It is defined in ASN.1 as: validity Validity Validity ::= SEQUENCE { notBefore CertificateValidityDate, notAfter CertificateValidityDate } CertificateValidityDate ::= CHOICE { utcTime UTCTime, generalTime GeneralizedTime }
|
checkValidity | back to summary |
---|---|
public abstract void checkValidity(Date date) throws CertificateExpiredException, CertificateNotYetValidException Checks that the given date is within the certificate's validity period. In other words, this determines whether the certificate would be valid at the given date/time.
|
getBasicConstraints | back to summary |
---|---|
public abstract int getBasicConstraints() Gets the certificate constraints path length from the
critical
The basic constraints extension identifies whether the subject
of the certificate is a Certificate Authority (CA) and
how deep a certification path may exist through that CA. The
The ASN.1 definition for this is: BasicConstraints ::= SEQUENCE { cA BOOLEAN DEFAULT FALSE, pathLenConstraint INTEGER (0..MAX) OPTIONAL }
|
getExtendedKeyUsage | back to summary |
---|---|
public List Gets an unmodifiable list of Strings representing the OBJECT
IDENTIFIERs of the ExtKeyUsageSyntax ::= SEQUENCE SIZE (1..MAX) OF KeyPurposeId KeyPurposeId ::= OBJECT IDENTIFIERKey purposes may be defined by any organization with a need. Object identifiers used to identify key purposes shall be assigned in accordance with IANA or ITU-T Rec. X.660 | ISO/IEC/ITU 9834-1.
This method was added to version 1.4 of the Java 2 Platform Standard
Edition. In order to maintain backwards compatibility with existing
service providers, this method is not
|
getIssuerAlternativeNames | back to summary |
---|---|
public Collection Gets an immutable collection of issuer alternative names from the
The ASN.1 definition of the IssuerAltName ::= GeneralNamesThe ASN.1 definition of GeneralNames is defined
in getSubjectAlternativeNames .
If this certificate does not contain an
Note that the
This method was added to version 1.4 of the Java 2 Platform Standard
Edition. In order to maintain backwards compatibility with existing
service providers, this method is not
|
getIssuerDN | back to summary |
---|---|
public abstract Principal getIssuerDN()
Deprecated since 16. Use Gets the The issuer name field contains an X.500 distinguished name (DN). The ASN.1 definition for this is: issuer Name Name ::= CHOICE { RDNSequence } RDNSequence ::= SEQUENCE OF RelativeDistinguishedName RelativeDistinguishedName ::= SET OF AttributeValueAssertion AttributeValueAssertion ::= SEQUENCE { AttributeType, AttributeValue } AttributeType ::= OBJECT IDENTIFIER AttributeValue ::= ANYThe Name describes a hierarchical name composed of
attributes,
such as country name, and corresponding values, such as US.
The type of the AttributeValue component is determined by
the AttributeType ; in general it will be a
directoryString . A directoryString is usually
one of PrintableString ,
TeletexString or UniversalString .
|
getIssuerUniqueID | back to summary |
---|---|
public abstract boolean[] getIssuerUniqueID() Gets the The ASN.1 definition for this is: issuerUniqueID [1] IMPLICIT UniqueIdentifier OPTIONAL UniqueIdentifier ::= BIT STRING
|
getIssuerX500Principal | back to summary |
---|---|
public X500Principal getIssuerX500Principal() Returns the issuer (issuer distinguished name) value from the
certificate as an It is recommended that subclasses override this method.
|
getKeyUsage | back to summary |
---|---|
public abstract boolean[] getKeyUsage() Gets a boolean array representing bits of
the KeyUsage ::= BIT STRING { digitalSignature (0), nonRepudiation (1), keyEncipherment (2), dataEncipherment (3), keyAgreement (4), keyCertSign (5), cRLSign (6), encipherOnly (7), decipherOnly (8) }RFC 5280 recommends that when used, this be marked as a critical extension.
|
getNotAfter | back to summary |
---|---|
public abstract Date getNotAfter() Gets the
|
getNotBefore | back to summary |
---|---|
public abstract Date getNotBefore() Gets the validity Validity Validity ::= SEQUENCE { notBefore CertificateValidityDate, notAfter CertificateValidityDate } CertificateValidityDate ::= CHOICE { utcTime UTCTime, generalTime GeneralizedTime }
|
getSerialNumber | back to summary |
---|---|
public abstract BigInteger getSerialNumber() Gets the serialNumber CertificateSerialNumber CertificateSerialNumber ::= INTEGER
|
getSigAlgName | back to summary |
---|---|
public abstract String getSigAlgName() Gets the signature algorithm name for the certificate signature algorithm. An example is the string "SHA256withRSA". The ASN.1 definition for this is: signatureAlgorithm AlgorithmIdentifier AlgorithmIdentifier ::= SEQUENCE { algorithm OBJECT IDENTIFIER, parameters ANY DEFINED BY algorithm OPTIONAL } -- contains a value of the type -- registered for use with the -- algorithm object identifier value The algorithm name is determined from the
|
getSigAlgOID | back to summary |
---|---|
public abstract String getSigAlgOID() Gets the signature algorithm OID string from the certificate. An OID is represented by a set of nonnegative whole numbers separated by periods. For example, the string "1.2.840.10040.4.3" identifies the SHA-1 with DSA signature algorithm defined in RFC 3279: Algorithms and Identifiers for the Internet X.509 Public Key Infrastructure Certificate and CRL Profile. See
|
getSigAlgParams | back to summary |
---|---|
public abstract byte[] getSigAlgParams() Gets the DER-encoded signature algorithm parameters from this
certificate's signature algorithm. In most cases, the signature
algorithm parameters are null; the parameters are usually
supplied with the certificate's public key.
If access to individual parameter values is needed then use
See
|
getSignature | back to summary |
---|---|
public abstract byte[] getSignature() Gets the signature BIT STRING
|
getSubjectAlternativeNames | back to summary |
---|---|
public Collection Gets an immutable collection of subject alternative names from the
The ASN.1 definition of the SubjectAltName ::= GeneralNames GeneralNames :: = SEQUENCE SIZE (1..MAX) OF GeneralName GeneralName ::= CHOICE { otherName [0] OtherName, rfc822Name [1] IA5String, dNSName [2] IA5String, x400Address [3] ORAddress, directoryName [4] Name, ediPartyName [5] EDIPartyName, uniformResourceIdentifier [6] IA5String, iPAddress [7] OCTET STRING, registeredID [8] OBJECT IDENTIFIER} OtherName ::= SEQUENCE { type-id OBJECT IDENTIFIER, value [0] EXPLICIT ANY DEFINED BY type-id }
If this certificate does not contain a
RFC 822, DNS, and URI
names are returned as
Note that the
This method was added to version 1.4 of the Java 2 Platform Standard
Edition. In order to maintain backwards compatibility with existing
service providers, this method is not Implementation Note The JDK SUN provider supports the third and fourth otherName entries.
|
getSubjectDN | back to summary |
---|---|
public abstract Principal getSubjectDN()
Deprecated since 16. Use Gets the The ASN.1 definition for this is: subject Name See
|
getSubjectUniqueID | back to summary |
---|---|
public abstract boolean[] getSubjectUniqueID() Gets the The ASN.1 definition for this is: subjectUniqueID [2] IMPLICIT UniqueIdentifier OPTIONAL UniqueIdentifier ::= BIT STRING
|
getSubjectX500Principal | back to summary |
---|---|
public X500Principal getSubjectX500Principal() Returns the subject (subject distinguished name) value from the
certificate as an It is recommended that subclasses override this method.
|
getTBSCertificate | back to summary |
---|---|
public abstract byte[] getTBSCertificate() throws CertificateEncodingException Gets the DER-encoded certificate information, the
|
getVersion | back to summary |
---|---|
public abstract int getVersion() Gets the version [0] EXPLICIT Version DEFAULT v1 Version ::= INTEGER { v1(0), v2(1), v3(2) }
|
verify | back to summary |
---|---|
public void verify(PublicKey key, Provider sigProvider) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, SignatureException Overrides java. Verifies that this certificate was signed using the
private key that corresponds to the specified public key.
This method uses the signature verification engine
supplied by the specified provider. Note that the specified
Provider object does not have to be registered in the provider list.
This method was added to version 1.8 of the Java Platform Standard
Edition. In order to maintain backwards compatibility with existing
service providers, this method is not
|