X500DistinguishedName Klasse
Definition
Wichtig
Einige Informationen beziehen sich auf Vorabversionen, die vor dem Release ggf. grundlegend überarbeitet werden. Microsoft übernimmt hinsichtlich der hier bereitgestellten Informationen keine Gewährleistungen, seien sie ausdrücklich oder konkludent.
Stellt den Distinguished Name eines X 509-Zertifikats dar. Diese Klasse kann nicht vererbt werden.
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
- Vererbung
Beispiele
Im folgenden Codebeispiel wird die Verwendung der X500DistinguishedName-Klasse veranschaulicht.
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
Hinweise
Diese Klasse ähnelt einer Erweiterung der SubjectName - oder IssuerName -Eigenschaft. Dies ist der Name der Person oder Entität, für die das Zertifikat ausgestellt wird. X.500 ist ein internationaler Standard für verteilte Verzeichnisdienste. Der distinguished Name verwendet das folgende Format:
[X500:/C=CountryCode/O=Organization/OU=OrganizationUnit/CN=CommonName]
Es gelten die folgenden Feldlängengrenzwerte:
Feld | Längenlimit |
---|---|
CountryCode | 2 Zeichen |
Organization | Bis zu 64 Zeichen |
OrganizationUnit | Bis zu 32 Zeichen |
CommonName | Bis zu 64 Zeichen |
Es gelten die folgenden Richtlinien:
Feldwerte können Groß- oder Kleinbuchstaben sein.
Trennzeichen sind Schrägstriche (/) und müssen vor dem ersten Wert und zwischen nachfolgenden Werten angezeigt werden.
Auf Trennzeichen kann ein Leerzeichen folgen.
Es folgt ein Beispiel für einen ordnungsgemäß formatierten Namen: [X500:/ C=US/ O=Microsoft/ OU=WGA/ CN=TedSt]
Konstruktoren
X500DistinguishedName(AsnEncodedData) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse mit dem angegebenen AsnEncodedData-Objekt. |
X500DistinguishedName(Byte[]) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse unter Verwendung des angegebenen Bytearrays. |
X500DistinguishedName(ReadOnlySpan<Byte>) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse unter Verwendung von Informationen aus den bereitgestellten Daten. |
X500DistinguishedName(String) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse unter Verwendung von Informationen aus der angegebenen Zeichenfolge. |
X500DistinguishedName(String, X500DistinguishedNameFlags) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse unter Verwendung der angegebenen Zeichenfolge und des X500DistinguishedNameFlags-Flags. |
X500DistinguishedName(X500DistinguishedName) |
Initialisiert eine neue Instanz der X500DistinguishedName-Klasse mit dem angegebenen X500DistinguishedName-Objekt. |
Eigenschaften
Name |
Ruft den durch Kommas getrennten Distinguished Name aus einem X500-Zertifikat ab. |
Oid |
Ruft den Oid-Wert für ein AsnEncodedData-Objekt ab oder legt diesen fest. (Geerbt von AsnEncodedData) |
RawData |
Ruft die in einem Bytearray dargestellten ASN.1-codierten (Abstract Syntax Notation One) Daten ab oder legt diese fest. (Geerbt von AsnEncodedData) |
Methoden
CopyFrom(AsnEncodedData) |
Kopiert Informationen aus einem AsnEncodedData-Objekt. (Geerbt von AsnEncodedData) |
Decode(X500DistinguishedNameFlags) |
Decodiert einen Distinguished Name mit dem vom |
EnumerateRelativeDistinguishedNames(Boolean) |
Durchläuft die RelativeDistinguishedName-Werte innerhalb dieses Distinguished Name-Werts. |
Equals(Object) |
Bestimmt, ob das angegebene Objekt gleich dem aktuellen Objekt ist. (Geerbt von Object) |
Format(Boolean) |
Gibt eine formatierte Version für einen X500-Distinguished Name zurück, der gedruckt oder in einem Textfenster oder einer Konsole ausgegeben werden kann. |
GetHashCode() |
Fungiert als Standardhashfunktion. (Geerbt von Object) |
GetType() |
Ruft den Type der aktuellen Instanz ab. (Geerbt von Object) |
MemberwiseClone() |
Erstellt eine flache Kopie des aktuellen Object. (Geerbt von Object) |
ToString() |
Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt. (Geerbt von Object) |