public class X509CRLSelector extends Object implements CRLSelector
X509CRLs
を選択する CRLSelector
です。このクラスは、証明書の取り消し状況をチェックするために CertStore
から CRL を選択するときに、特に役立ちます。
最初に構築された X509CRLSelector
には有効な基準が含まれていないため、各 get
メソッドはデフォルト値 (null
) を返します。したがって、match
メソッドは、X509CRL
に対して true
を返します。通常、X509CRLSelector
は、setIssuers
や setDateAndTime
を呼び出していくつかの基準を有効にしたあと、CertStore.getCRLs
や類似のメソッドに渡されます。
これから説明する X.509 CRL フィールドと機能拡張の定義については、RFC 3280「Internet X.509 Public Key Infrastructure Certificate and CRL Profile」を参照してください。
並行アクセス
特に断らないかぎり、このクラスで定義されているメソッドはスレッドセーフではありません。単一のオブジェクトに並行アクセスする必要のある複数スレッドは、スレッド間で同期をとり、必要に応じてロックする必要があります。複数のスレッドがそれぞれ個別のオブジェクトを処理する場合、それらのスレッドは同期する必要はありません。
CRLSelector
, X509CRL
コンストラクタと説明 |
---|
X509CRLSelector()
X509CRLSelector を作成します。 |
修飾子と型 | メソッドと説明 |
---|---|
void |
addIssuer(X500Principal issuer)
名前を issurNames の基準値に追加します。
|
void |
addIssuerName(byte[] name)
名前を issurNames の基準値に追加します。
|
void |
addIssuerName(String name)
バグ: 代わりに addIssuer(X500Principal) または addIssuerName(byte[]) を使用してください。
|
Object |
clone()
このオブジェクトの複製を返します。
|
X509Certificate |
getCertificateChecking()
チェック対象の証明書を返します。
|
Date |
getDateAndTime()
dateAndTime 基準値を返します。
|
Collection<Object> |
getIssuerNames()
issurNames の基準値の複製を返します。
|
Collection<X500Principal> |
getIssuers()
issurNames の基準値を返します。
|
BigInteger |
getMaxCRL()
maxCRLNumber 基準値を返します。
|
BigInteger |
getMinCRL()
minCRLNumber 基準値を返します。
|
boolean |
match(CRL crl)
CRL が選択されるかどうかを判断します。 |
void |
setCertificateChecking(X509Certificate cert)
チェック対象の証明書を設定します。
|
void |
setDateAndTime(Date dateAndTime)
dateAndTime 基準値を設定します。
|
void |
setIssuerNames(Collection<?> names)
注: 代わりに setIssuers(Collection) を使用するか、このメソッドを使用する際にバイト配列形式の識別名のみを指定してください。
|
void |
setIssuers(Collection<X500Principal> issuers)
issurNames の基準値を設定します。
|
void |
setMaxCRLNumber(BigInteger maxCRL)
maxCRLNumber 基準値を設定します。
|
void |
setMinCRLNumber(BigInteger minCRL)
minCRLNumber 基準値を設定します。
|
String |
toString()
X509CRLSelector のプリント可能表現を返します。 |
public X509CRLSelector()
X509CRLSelector
を作成します。最初は条件が設定されていないため、どの X509CRL
でも一致します。public void setIssuers(Collection<X500Principal> issuers)
X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。null
の場合、発行者識別名は問われません。
このメソッドを使用すると、呼び出し側は、1 回のメソッド呼び出しで、X509CRLs
に含まれる発行者名の完全なセットを指定できます。指定した値で issuerNames 基準値の前の値が置き換えられます。
names
パラメータが null
ではない場合は、X500Principal
の Collection
です。
names
パラメータには重複した識別名が含まれていることがありますが、それらは getIssuers
メソッドから返された名前の Collection
から削除できます。
以後の変更から保護するために、Collection
にコピーが行われます。
issuers
- X500Principals の Collection
(または null
)getIssuers()
public void setIssuerNames(Collection<?> names) throws IOException
addIssuerName(String)
を参照してください。
issurNames の基準値を設定します。X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。null
の場合、発行者識別名は問われません。
このメソッドを使用すると、呼び出し側は、1 回のメソッド呼び出しで、X509CRLs
に含まれる発行者名の完全なセットを指定できます。指定した値で issuerNames 基準値の前の値が置き換えられます。
names
パラメータが null
ではない場合は、名前の Collection
です。それぞれの名前は String
か、識別名を表すバイト配列 (それぞれが RFC 2253 または ASN.1 DER 符号化形式) です。この引数の値として null
が指定された場合、issurNames のチェックは行われません。
names
パラメータには重複した識別名が含まれていることがありますが、それらは getIssuerNames
メソッドから返された名前の Collection
から削除できます。
名前がバイト配列で指定された場合、X.501 で定義されている DER 符号化された単一識別名が含まれる必要があります。この構造体の ASN.1 表記は次のようになります。
Name ::= CHOICE {
RDNSequence }
RDNSequence ::= SEQUENCE OF RelativeDistinguishedName
RelativeDistinguishedName ::=
SET SIZE (1 .. MAX) OF AttributeTypeAndValue
AttributeTypeAndValue ::= SEQUENCE {
type AttributeType,
value AttributeValue }
AttributeType ::= OBJECT IDENTIFIER
AttributeValue ::= ANY DEFINED BY AttributeType
....
DirectoryString ::= CHOICE {
teletexString TeletexString (SIZE (1..MAX)),
printableString PrintableString (SIZE (1..MAX)),
universalString UniversalString (SIZE (1..MAX)),
utf8String UTF8String (SIZE (1.. MAX)),
bmpString BMPString (SIZE (1..MAX)) }
以後の変更から保護するために、Collection
にディープコピーが行われます。
names
- 名前の Collection
。または null
IOException
- 構文解析エラーが発生した場合getIssuerNames()
public void addIssuer(X500Principal issuer)
X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。
このメソッドでは、呼び出し側が名前を X509CRLs
に含まれる発行者名のセットに追加できます。指定した名前は、issuerNames 基準で先に存在する値に追加されます。指定した名前が重複する場合は無視されます。
issuer
- X500Principal としての発行者public void addIssuerName(String name) throws IOException
名前を issurNames の基準値に追加します。X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。
このメソッドでは、呼び出し側が名前を X509CRLs
に含まれる発行者名のセットに追加できます。指定した名前は、issuerNames 基準で先に存在する値に追加されます。指定した名前が重複する場合は無視されます。
name
- RFC 2253 形式の名前IOException
- 構文解析エラーが発生した場合public void addIssuerName(byte[] name) throws IOException
X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。
このメソッドでは、呼び出し側が名前を X509CRLs
に含まれる発行者名のセットに追加できます。指定した名前は、issuerNames 基準で先に存在する値に追加されます。指定した名前が重複する場合は無視されます。名前がバイト配列で指定された場合、X.501 で定義されている DER 符号化された単一識別名が含まれる必要があります。この構造体の ASN.1 表記は次のようになります。
名前はバイト配列で指定されます。このバイト配列には、X.501 で定義されている DER 符号化された単一識別名が含まれる必要があります。この構造体の ASN.1 表記は、setIssuerNames(Collection names)
で説明しています。
以後の変更から保護するために、ここで提供されるバイト配列は複製されています。
name
- ASN.1 DER 符号化形式による名前を含むバイト配列IOException
- 構文解析エラーが発生した場合public void setMinCRLNumber(BigInteger minCRL)
X509CRL
では、CRL 数拡張機能がなければいけません。CRL 数拡張機能の値は指定した値以上になります。null
の場合、minCRLNumber のチェックは行われません。minCRL
- 許容される最小 CRL 数。または null
public void setMaxCRLNumber(BigInteger maxCRL)
X509CRL
では、CRL 数拡張機能がなければいけません。CRL 数拡張機能の値は指定した値以下になります。null
が指定された場合、maxCRLNumber のチェックは行われません。maxCRL
- 許容される最大 CRL 数。または null
public void setDateAndTime(Date dateAndTime)
X509CRL
の thisUpdate コンポーネントの値以降で、かつ nextUpdate コンポーネントの値以前でなければいけません。X509CRL
に nextUpdate コンポーネントが含まれていない場合は、一致する日付はありません。null
の場合、dateAndTime のチェックは行われません。
以後の変更から保護するために、ここで提供される Date
は複製されています。
dateAndTime
- 一致させる Date
。または null
getDateAndTime()
public void setCertificateChecking(X509Certificate cert)
CertStore
が関連する CRL を検索するのに役立つオプション情報です。null
が指定された場合、このようなオプション情報は提供されません。cert
- チェック対象の X509Certificate
。または null
getCertificateChecking()
public Collection<X500Principal> getIssuers()
X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。返された値が null
の場合は、発行者識別名は問われません。
戻り値が null
でない場合、その戻り値は、X500Principal
の変更不可能な Collection
です。
Collection
。または null
setIssuers(java.util.Collection<javax.security.auth.x500.X500Principal>)
public Collection<Object> getIssuerNames()
X509CRL
にある発行者識別名は、指定された識別名の少なくとも 1 つと一致する必要があります。返された値が null
の場合は、発行者識別名は問われません。
返された値が null
ではない場合は、名前の Collection
になります。それぞれの名前は String
か、識別名を表すバイト配列 (それぞれが RFC 2253 または ASN.1 DER 符号化形式) です。返される Collection
には、重複する名前が含まれていることがあります。
名前がバイト配列で指定された場合、X.501 で定義されている DER 符号化された単一識別名が含まれる必要があります。この構造体の ASN.1 表記については、setIssuerNames(Collection names)
のドキュメントを参照してください。
以後の変更から保護するために、Collection
にディープコピーが行われます。
Collection
。または null
setIssuerNames(java.util.Collection<?>)
public BigInteger getMinCRL()
X509CRL
では、CRL 数拡張機能がなければいけません。CRL 数拡張機能の値は指定した値以上になります。null
の場合、minCRLNumber のチェックは行われません。null
public BigInteger getMaxCRL()
X509CRL
では、CRL 数拡張機能がなければいけません。CRL 数拡張機能の値は指定した値以下になります。null
が指定された場合、maxCRLNumber のチェックは行われません。null
public Date getDateAndTime()
X509CRL
の thisUpdate コンポーネントの値以降で、かつ nextUpdate コンポーネントの値以前でなければいけません。X509CRL
に nextUpdate コンポーネントが含まれていない場合は、一致する日付はありません。null
の場合、dateAndTime のチェックは行われません。
以後の変更から保護するために、返される Date
は複製されています。
Date
。または null
setDateAndTime(java.util.Date)
public X509Certificate getCertificateChecking()
CertStore
が関連する CRL を検索するのに役立つオプション情報です。返された値が null
の場合、そのような追加情報は提供されません。null
setCertificateChecking(java.security.cert.X509Certificate)
public String toString()
X509CRLSelector
のプリント可能表現を返します。public boolean match(CRL crl)
CRL
が選択されるかどうかを判断します。match
、インタフェース: CRLSelector
crl
- チェック対象の CRL
CRL
が選択される場合は true
、そうでない場合は false
バグまたは機能を送信
詳細な API リファレンスおよび開発者ドキュメントについては、Java SE のドキュメントを参照してください。そのドキュメントには、概念的な概要、用語の定義、回避方法、有効なコード例などの、開発者を対象にしたより詳細な説明が含まれています。
Copyright © 1993, 2013, Oracle and/or its affiliates. All rights reserved.