英語で読む

次の方法で共有


X509Extension クラス

定義

X509 拡張を表します。

C#
public class X509Extension : System.Security.Cryptography.AsnEncodedData
継承
X509Extension
派生

次のコード例では、 クラスの使用方法を X509Extension 示します。

C#
using System;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;

public class CertSelect
{
    public static void Main()
    {
        try
        {
            X509Store store = new X509Store("MY", StoreLocation.CurrentUser);
            store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);

            X509Certificate2Collection collection = (X509Certificate2Collection)store.Certificates;
            for (int i = 0; i < collection.Count; i++)
            {
                foreach (X509Extension extension in collection[i].Extensions)
                {
                    Console.WriteLine(extension.Oid.FriendlyName + "(" + extension.Oid.Value + ")");

                    if (extension.Oid.FriendlyName == "Key Usage")
                    {
                        X509KeyUsageExtension ext = (X509KeyUsageExtension)extension;
                        Console.WriteLine(ext.KeyUsages);
                    }

                    if (extension.Oid.FriendlyName == "Basic Constraints")
                    {
                        X509BasicConstraintsExtension ext = (X509BasicConstraintsExtension)extension;
                        Console.WriteLine(ext.CertificateAuthority);
                        Console.WriteLine(ext.HasPathLengthConstraint);
                        Console.WriteLine(ext.PathLengthConstraint);
                    }

                    if (extension.Oid.FriendlyName == "Subject Key Identifier")
                    {
                        X509SubjectKeyIdentifierExtension ext = (X509SubjectKeyIdentifierExtension)extension;
                        Console.WriteLine(ext.SubjectKeyIdentifier);
                    }

                    if (extension.Oid.FriendlyName == "Enhanced Key Usage")
                    {
                        X509EnhancedKeyUsageExtension ext = (X509EnhancedKeyUsageExtension)extension;
                        OidCollection oids = ext.EnhancedKeyUsages;
                        foreach (Oid oid in oids)
                        {
                            Console.WriteLine(oid.FriendlyName + "(" + oid.Value + ")");
                        }
                    }
                }
            }
            store.Close();
        }
        catch (CryptographicException)
        {
            Console.WriteLine("Information could not be written out for this certificate.");
        }
    }
}

注釈

X509 拡張機能は、X509 証明書に追加して変更できる動的な拡張プロパティです。 クラスを X509Extension 使用して、証明書に関連付けられているが、証明機関 (CA) によって発行された証明書の一部ではない拡張機能を作成できます。

X509 拡張機能の最も基本的な形式では、オブジェクト識別子 (OID)、拡張機能が重要と見なされるかどうかを示すブール値、および ASN でエンコードされたデータがあります。 カスタム拡張機能は、ファイルに CryptoConfig 登録できます。

The.NET Framework には、いくつかの一般的な X509 拡張機能の実装が含まれています。

コンストラクター

X509Extension()

X509Extension クラスの新しいインスタンスを初期化します。

X509Extension(AsnEncodedData, Boolean)

X509Extension クラスの新しいインスタンスを初期化します。

X509Extension(Oid, Byte[], Boolean)

X509Extension クラスの新しいインスタンスを初期化します。

X509Extension(Oid, ReadOnlySpan<Byte>, Boolean)

X509Extension クラスの新しいインスタンスを初期化します。

X509Extension(String, Byte[], Boolean)

X509Extension クラスの新しいインスタンスを初期化します。

X509Extension(String, ReadOnlySpan<Byte>, Boolean)

X509Extension クラスの新しいインスタンスを初期化します。

プロパティ

Critical

拡張機能がクリティカルであるかどうかを示すブール値を取得します。

Oid

Oid オブジェクトの AsnEncodedData 値を取得または設定します。

(継承元 AsnEncodedData)
RawData

ASN.1 (Abstract Syntax Notation One) でエンコードされたデータをバイト配列表現で取得または設定します。

(継承元 AsnEncodedData)

メソッド

CopyFrom(AsnEncodedData)

指定された AsnEncodedData オブジェクトの拡張機能プロパティをコピーします。

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。

(継承元 Object)
Format(Boolean)

ASN.1 (Abstract Syntax Notation One) でエンコードされたデータを、文字列として書式設定して返します。

(継承元 AsnEncodedData)
GetHashCode()

既定のハッシュ関数として機能します。

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。

(継承元 Object)
ToString()

現在のオブジェクトを表す文字列を返します。

(継承元 Object)

適用対象

製品 バージョン
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1