java.lang.Object
java.security.cert.Certificate
- すべての実装されたインタフェース:
Serializable
- 直系の既知のサブクラス:
X509Certificate
public abstract class Certificate extends Object implements Serializable
さまざまな身元証明書を管理するabstractクラスです。 身元証明書とは、ほかの主体によって保証された公開キーに主体をバインドしたものです。 (主体とは個人ユーザー、グループ、会社などのエンティティを表します。)
このクラスは、形式は異なるが主要な機能は共通である、複数の証明書を抽象化したものです。 たとえば、X.509やPGPなどの各種の証明書は、一般的な証明書の機能(エンコーディングや検証など)と、一部の種類の情報(公開キーなど)を共有しています。
X.509、PGP、およびSDSIの証明書には、それぞれ異なる種類の情報のセットが格納され、情報の格納と取出しの方法が異なります。しかしこれらの証明書はすべて、Certificateクラスのサブクラス化によって実装できます。
- 導入されたバージョン:
- 1.2
- 関連項目:
-
ネストされたクラスのサマリー
ネストされたクラス -
コンストラクタのサマリー
コンストラクタ -
メソッドのサマリー
修飾子と型メソッド説明boolean
この証明書と、指定されたオブジェクトが等しいかどうかを判定します。abstract byte[]
この証明書のエンコードされた形式を返します。abstract PublicKey
この証明書から公開キーを取得します。final String
getType()
この証明書のタイプを返します。int
hashCode()
エンコードされた形式からこの証明書のハッシュ・コード値を返します。abstract String
toString()
この証明書の文字列表現を返します。abstract void
指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。abstract void
指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。void
指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。protected Object
直列化されるCertificate
を、Certificate
のタイプおよびエンコードされたバイトを含むCertificateRep
オブジェクトに置き換えます。
-
コンストラクタの詳細
-
証明書
protected Certificate(String type) 指定されたタイプの証明書を作成します。- パラメータ:
type
- 証明書タイプの標準名。 標準証明書型については、「Javaセキュリティ標準アルゴリズム名指定」のCertificateFactoryセクションを参照してください。
-
-
メソッドの詳細
-
getType
public final String getType()この証明書のタイプを返します。- 戻り値:
- この証明書のタイプ。
-
equals
public boolean equals(Object other) この証明書と、指定されたオブジェクトが等しいかどうかを判定します。other
オブジェクトがinstanceof
Certificate
の場合、エンコードされた形式が取得され、この証明書のエンコードされた形式と比較されます。 -
hashCode
public int hashCode()エンコードされた形式からこの証明書のハッシュ・コード値を返します。 -
getEncoded
public abstract byte[] getEncoded() throws CertificateEncodingExceptionこの証明書のエンコードされた形式を返します。 各証明書タイプは、1つのエンコード方式を使用することになっています。たとえば、X.509証明書は、ASN.1 DERとしてエンコードされます。- 戻り値:
- この証明書の符号化された形式
- 例外:
CertificateEncodingException
- 符号化エラーが発生した場合。
-
verify
public abstract void verify(PublicKey key) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException 指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。- パラメータ:
key
- 検証の実行に使うPublicKey。- 例外:
NoSuchAlgorithmException
- サポートされていない署名アルゴリズムの場合。InvalidKeyException
- 無効なキーの場合NoSuchProviderException
- デフォルトのプロバイダがない場合。SignatureException
- 署名エラーの場合。CertificateException
- 符号化エラーの場合。
-
verify
public abstract void verify(PublicKey key, String sigProvider) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException 指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。 このメソッドは、指定されたプロバイダによって提供される署名検証エンジンを使用します。- パラメータ:
key
- 検証の実行に使うPublicKey。sigProvider
- 署名プロバイダの名前。- 例外:
NoSuchAlgorithmException
- サポートされていない署名アルゴリズムの場合。InvalidKeyException
- 無効なキーの場合NoSuchProviderException
- 無効なプロバイダの場合。SignatureException
- 署名エラーの場合。CertificateException
- 符号化エラーの場合。
-
verify
public void verify(PublicKey key, Provider sigProvider) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, SignatureException 指定された公開キーに対応する非公開キーを使って、この証明書が署名されたことを検証します。 このメソッドは、指定されたプロバイダによって提供される署名検証エンジンを使用します。 指定されたProviderオブジェクトは、プロバイダ・リストに登録する必要はありません。このメソッドは、Java Platform Standard Editionのバージョン1.8で追加されました。 既存のサービス・プロバイダとの下位互換性を維持するため、このメソッドは
abstract
にはできず、デフォルトでUnsupportedOperationException
をスローします。- パラメータ:
key
- 検証の実行に使うPublicKey。sigProvider
- 署名プロバイダ。- 例外:
NoSuchAlgorithmException
- サポートされていない署名アルゴリズムの場合。InvalidKeyException
- 無効なキーの場合SignatureException
- 署名エラーの場合。CertificateException
- 符号化エラーの場合。UnsupportedOperationException
- メソッドがサポートされていない場合- 導入されたバージョン:
- 1.8
-
toString
public abstract String toString()この証明書の文字列表現を返します。 -
getPublicKey
public abstract PublicKey getPublicKey()この証明書から公開キーを取得します。- 戻り値:
- 公開キー。
-
writeReplace
protected Object writeReplace() throws ObjectStreamException直列化されるCertificate
を、Certificate
のタイプおよびエンコードされたバイトを含むCertificateRep
オブジェクトに置き換えます。- 戻り値:
Certificate
のタイプおよびエンコードされたバイトを含むCertificateRep
オブジェクト- 例外:
ObjectStreamException
- このCertificate
を表すCertificateRep
オブジェクトを作成できなかった場合- 導入されたバージョン:
- 1.3
-