Sdílet prostřednictvím


X500DistinguishedName Třída

Definice

Představuje rozlišující název certifikátu X509. Tato třída se nemůže dědit.

public ref class X500DistinguishedName sealed : System::Security::Cryptography::AsnEncodedData
public sealed class X500DistinguishedName : System.Security.Cryptography.AsnEncodedData
type X500DistinguishedName = class
    inherit AsnEncodedData
Public NotInheritable Class X500DistinguishedName
Inherits AsnEncodedData
Dědičnost
X500DistinguishedName

Příklady

Následující příklad kódu ukazuje, jak použít X500DistinguishedName třídu .

using System;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;

class X500Sample
{
    static void Main()
    {
        try
        {
            X509Store store = new("MY", StoreLocation.CurrentUser);
            store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);
            X509Certificate2Collection collection = store.Certificates;
            X509Certificate2Collection fcollection = collection.Find(
                X509FindType.FindByTimeValid,
                DateTime.Now, false
                );
            X509Certificate2Collection scollection = X509Certificate2UI.SelectFromCollection(
                fcollection,
                "Test Certificate Select",
                "Select a certificate from the following list to get information on that certificate",
                X509SelectionFlag.MultiSelection
                );
            Console.WriteLine($"Number of certificates: {scollection.Count}{Environment.NewLine}");
            foreach (X509Certificate2 x509 in scollection)
            {
                X500DistinguishedName dname = new(
                    x509.SubjectName.Name,
                    X500DistinguishedNameFlags.Reversed | X500DistinguishedNameFlags.UseSemicolons
                    );
                Console.WriteLine("X500DistinguishedName: {0}{1}", dname.Name, Environment.NewLine);
                x509.Reset();
            }
            store.Close();
        }
        catch (CryptographicException)
        {
            Console.WriteLine("Information could not be written out for this certificate.");
        }
    }
}
Imports System.Security.Cryptography.X509Certificates

Class X500Sample
    Shared s_msg As String
    Shared Sub Main()

        Try
            Dim store As New X509Store("MY", StoreLocation.CurrentUser)
            store.Open(OpenFlags.ReadOnly Or OpenFlags.OpenExistingOnly)
            Dim collection As X509Certificate2Collection = store.Certificates
            Dim fcollection As X509Certificate2Collection = collection.Find(X509FindType.FindByTimeValid, Date.Now, False)
            Dim scollection As X509Certificate2Collection = X509Certificate2UI.SelectFromCollection(
                fcollection,
                "Test Certificate Select",
                "Select a certificate from the following list to get information on that certificate",
                X509SelectionFlag.MultiSelection
                )
            s_msg = "Number of certificates: " & scollection.Count & Environment.NewLine
            Console.WriteLine(s_msg)
            Dim x509 As X509Certificate2
            For Each x509 In scollection
                Dim dname As New X500DistinguishedName(
                x509.SubjectName.Name,
                X500DistinguishedNameFlags.Reversed Or X500DistinguishedNameFlags.UseSemicolons
                )
                s_msg = "X500DistinguishedName: " & dname.Name & Environment.NewLine
                Console.WriteLine(s_msg)
                x509.Reset()
            Next x509
            store.Close()
        Catch e As Exception
            s_msg = "Error: Information could not be written out for this certificate."
            Console.WriteLine(s_msg)
        End Try
    End Sub
End Class

Poznámky

Tato třída je jako rozšíření SubjectName vlastnosti nebo IssuerName , což je název osoby nebo entity, které je certifikát vystaven. X.500 je mezinárodní standard pro distribuované adresářové služby. Rozlišující název používá následující formát:

[X500:/C=CountryCode/O=Organization/OU=OrganizationUnit/CN=CommonName]

Platí následující omezení délky pole:

Pole Limit délky
CountryCode 2 znaky
Organizace Až 64 znaků
Organizační jednotka Až 32 znaků
CommonName Až 64 znaků

Platí následující pokyny:

  • Hodnoty polí můžou být velké nebo malé.

  • Oddělovače jsou lomítka (/) a musí být uvedeny před první hodnotou a mezi následujícími hodnotami.

  • Za oddělovači může následovat mezera.

Následuje příklad správně naformátovaného názvu: [X500:/ C=US/ O=Microsoft/ OU=WGA/ CN=TedSt]

Konstruktory

X500DistinguishedName(AsnEncodedData)

Inicializuje novou instanci X500DistinguishedName třídy pomocí zadaného AsnEncodedData objektu.

X500DistinguishedName(Byte[])

Inicializuje novou instanci X500DistinguishedName třídy pomocí informací ze zadaného pole bajtů.

X500DistinguishedName(ReadOnlySpan<Byte>)

Inicializuje novou instanci X500DistinguishedName třídy pomocí informací ze zadaných dat.

X500DistinguishedName(String)

Inicializuje novou instanci X500DistinguishedName třídy pomocí informací ze zadaného řetězce.

X500DistinguishedName(String, X500DistinguishedNameFlags)

Inicializuje novou instanci X500DistinguishedName třídy pomocí zadaného řetězce a X500DistinguishedNameFlags příznaku.

X500DistinguishedName(X500DistinguishedName)

Inicializuje novou instanci X500DistinguishedName třídy pomocí zadaného X500DistinguishedName objektu.

Vlastnosti

Name

Získá rozlišující název oddělený čárkami z certifikátu X500.

Oid

Získá nebo nastaví Oid hodnotu objektu AsnEncodedData .

(Zděděno od AsnEncodedData)
RawData

Získá nebo nastaví abstraktní syntaxe notation one (ASN.1) kódované data reprezentované v bajtovém poli.

(Zděděno od AsnEncodedData)

Metody

CopyFrom(AsnEncodedData)

Zkopíruje informace z objektu AsnEncodedData .

(Zděděno od AsnEncodedData)
Decode(X500DistinguishedNameFlags)

Dekóduje rozlišující název pomocí vlastností určených parametrem flag .

EnumerateRelativeDistinguishedNames(Boolean)

Iteruje hodnoty RelativeDistinguishedName v rámci této hodnoty rozlišujícího názvu.

Equals(Object)

Určí, zda se zadaný objekt rovná aktuálnímu objektu.

(Zděděno od Object)
Format(Boolean)

Vrátí formátovanou verzi rozlišujícího názvu X500 pro tisk nebo výstup do textového okna nebo do konzoly.

GetHashCode()

Slouží jako výchozí hashovací funkce.

(Zděděno od Object)
GetType()

Type Získá z aktuální instance.

(Zděděno od Object)
MemberwiseClone()

Vytvoří mělkou kopii aktuálního Objectsouboru .

(Zděděno od Object)
ToString()

Vrátí řetězec, který představuje aktuální objekt.

(Zděděno od Object)

Platí pro