public class CertPathBuilder extends Object
このクラスは、プロバイダ・ベースのアーキテクチャを使用します。CertPathBuilder
を作成するには、static getInstance
メソッドのうちの1つを呼び出して、作成するCertPathBuilder
のアルゴリズム名とプロバイダ名(オプション)を渡します。
CertPathBuilder
オブジェクトが作成されると、build
メソッドを呼び出してアルゴリズム固有のパラメータ・セットを渡すことで、証明書パスが構築されます。証明書パスの構築に成功すると、CertPathBuilderResult
インタフェースを実装するオブジェクトにその結果(構築したCertPath
を含む)が返されます。
アプリケーションはgetRevocationChecker()
メソッドを使用して、CertPathBuilder
が証明書の失効ステータスをチェックするときに使用する追加のアルゴリズム固有のパラメータおよびオプションを指定できます。次の例は、PKIXアルゴリズムでの使用方法を示しています。
CertPathBuilder cpb = CertPathBuilder.getInstance("PKIX"); PKIXRevocationChecker rc = (PKIXRevocationChecker)cpb.getRevocationChecker(); rc.setOptions(EnumSet.of(Option.PREFER_CRLS)); params.addCertPathChecker(rc); CertPathBuilderResult cpbr = cpb.build(params);
Javaプラットフォームの実装は、すべて次の標準のCertPathBuilder
アルゴリズムをサポートする必要があります。
PKIX
並行アクセス
このクラスのstaticメソッドは、スレッドセーフであることが保証されています。このクラスで定義されているstaticメソッドは、悪影響を与えることなく、複数スレッドが並行して呼び出すことができます。
しかしこのことは、このクラスで定義されている非staticメソッドには当てはまりません。特定のプロバイダで特に説明がないかぎり、単一のCertPathBuilder
インスタンスに並行してアクセスする必要のある複数スレッドは、スレッド間で同期を取り、必要に応じてロックしなければいけません。異なるCertPathBuilder
インスタンスを操作する複数スレッドは、同期化される必要はありません。
CertPath
修飾子 | コンストラクタと説明 |
---|---|
protected |
CertPathBuilder(CertPathBuilderSpi builderSpi, Provider provider, String algorithm)
指定されたアルゴリズムの
CertPathBuilder オブジェクトを作成し、指定されたプロバイダの実装(SPIオブジェクト)をそこにカプセル化します。 |
修飾子と型 | メソッドと説明 |
---|---|
CertPathBuilderResult |
build(CertPathParameters params)
指定したアルゴリズムのパラメータ・セットを使用して、証明書パスを構築しようとします。
|
String |
getAlgorithm()
この
CertPathBuilder のアルゴリズム名を返します。 |
static String |
getDefaultType()
certpathbuilder.type セキュリティ・プロパティに指定されているデフォルトのCertPathBuilder タイプを返します。該当するプロパティが存在しない場合は、文字列「PKIX」を返します。 |
static CertPathBuilder |
getInstance(String algorithm)
指定されたアルゴリズムを実装する
CertPathBuilder オブジェクトを返します。 |
static CertPathBuilder |
getInstance(String algorithm, Provider provider)
指定されたアルゴリズムを実装する
CertPathBuilder オブジェクトを返します。 |
static CertPathBuilder |
getInstance(String algorithm, String provider)
指定されたアルゴリズムを実装する
CertPathBuilder オブジェクトを返します。 |
Provider |
getProvider()
この
CertPathBuilder のプロバイダを返します。 |
CertPathChecker |
getRevocationChecker()
カプセル化された
CertPathBuilderSpi 実装が証明書の失効ステータスをチェックするために使用するCertPathChecker を返します。 |
protected CertPathBuilder(CertPathBuilderSpi builderSpi, Provider provider, String algorithm)
CertPathBuilder
オブジェクトを作成し、指定されたプロバイダの実装(SPIオブジェクト)をそこにカプセル化します。builderSpi
- プロバイダの実装provider
- プロバイダalgorithm
- アルゴリズム名public static CertPathBuilder getInstance(String algorithm) throws NoSuchAlgorithmException
CertPathBuilder
オブジェクトを返します。
このメソッドは、最優先のProviderから順に、登録済みのセキュリティProviderのリストをトラバースします。指定されたアルゴリズムをサポートする最初のProviderのCertPathBuilderSpi実装をカプセル化する新しいCertPathBuilderオブジェクトが返されます。
登録済みプロバイダのリストは、Security.getProviders()
メソッド経由で取得できます。
algorithm
- 要求するCertPathBuilder
アルゴリズムの名前。アルゴリズムの標準名については、Java暗号化アーキテクチャ標準アルゴリズム名のドキュメントのCertPathBuilderのセクションを参照。CertPathBuilder
オブジェクト。NoSuchAlgorithmException
- 指定されたアルゴリズムのCertPathBuilderSpi実装をサポートするProviderが存在しない場合。Provider
public static CertPathBuilder getInstance(String algorithm, String provider) throws NoSuchAlgorithmException, NoSuchProviderException
CertPathBuilder
オブジェクトを返します。
指定されたプロバイダのCertPathBuilderSpi実装をカプセル化する新しいCertPathBuilderオブジェクトが返されます。指定したプロバイダは、セキュリティ・プロバイダ・リストに登録する必要があります。
登録済みプロバイダのリストは、Security.getProviders()
メソッド経由で取得できます。
algorithm
- 要求するCertPathBuilder
アルゴリズムの名前。アルゴリズムの標準名については、Java暗号化アーキテクチャ標準アルゴリズム名のドキュメントのCertPathBuilderのセクションを参照。provider
- プロバイダ名。CertPathBuilder
オブジェクト。NoSuchAlgorithmException
- 指定されたプロバイダに指定されたアルゴリズムのCertPathBuilderSpiの実装がない場合。NoSuchProviderException
- 指定されたプロバイダがセキュリティ・プロバイダ・リストに登録されていない場合。IllegalArgumentException
- provider
がnullまたは空の場合。Provider
public static CertPathBuilder getInstance(String algorithm, Provider provider) throws NoSuchAlgorithmException
CertPathBuilder
オブジェクトを返します。
指定されたProviderオブジェクトのCertPathBuilderSpi実装をカプセル化する新しいCertPathBuilderオブジェクトが返されます。指定されたProviderオブジェクトは、プロバイダ・リストに登録する必要はありません。
algorithm
- 要求するCertPathBuilder
アルゴリズムの名前。アルゴリズムの標準名については、Java暗号化アーキテクチャ標準アルゴリズム名のドキュメントのCertPathBuilderのセクションを参照。provider
- プロバイダCertPathBuilder
オブジェクト。NoSuchAlgorithmException
- 指定されたProviderオブジェクトに指定されたアルゴリズムのCertPathBuilderSpiの実装がない場合。IllegalArgumentException
- provider
がnullの場合。Provider
public final Provider getProvider()
CertPathBuilder
のプロバイダを返します。CertPathBuilder
のプロバイダpublic final String getAlgorithm()
CertPathBuilder
のアルゴリズム名を返します。CertPathBuilder
のアルゴリズム名public final CertPathBuilderResult build(CertPathParameters params) throws CertPathBuilderException, InvalidAlgorithmParameterException
params
- アルゴリズム・パラメータCertPathBuilderException
- 指定されたパラメータを満たす証明書パスを構築できなかった場合InvalidAlgorithmParameterException
- 指定されたパラメータが次に対して不適切な場合: CertPathBuilder
public static final String getDefaultType()
certpathbuilder.type
セキュリティ・プロパティに指定されているデフォルトのCertPathBuilder
タイプを返します。該当するプロパティが存在しない場合は、文字列「PKIX」を返します。
デフォルトのCertPathBuilder
タイプを使用するのは、アプリケーションでgetInstance
メソッドを呼び出すときにハードコードされたタイプを使用しない場合、およびユーザーが独自のタイプを指定しないときにデフォルトのタイプを提供する場合です。
デフォルトのCertPathBuilder
タイプは、certpathbuilder.type
セキュリティ・プロパティの値を目的のタイプに設定することで変更できます。
certpathbuilder.type
セキュリティ・プロパティに指定されているデフォルトのCertPathBuilder
タイプ、該当するプロパティが存在しない場合は文字列「PKIX」。セキュリティ・プロパティ
public final CertPathChecker getRevocationChecker()
CertPathBuilderSpi
実装が証明書の失効ステータスをチェックするために使用するCertPathChecker
を返します。PKIX実装は、PKIXRevocationChecker
型のオブジェクトを返します。このメソッドを呼び出すたびに、CertPathChecker
の新しいインスタンスが返されます。
このメソッドの主な目的は、呼出し側が失効チェックに固有の追加の入力パラメータおよびオプションを指定できるようにすることです。具体例については、クラスの説明を参照してください。
CertPathChecker
UnsupportedOperationException
- サービス・プロバイダがこのメソッドをサポートしない場合 バグまたは機能を送信
詳細なAPIリファレンスおよび開発者ドキュメントについては、Java SEのドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright© 1993, 2014, Oracle and/or its affiliates. All rights reserved.