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 distinguishierten Namen eines X509-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
Das folgende Codebeispiel zeigt, wie die X500DistinguishedName Klasse verwendet wird.
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 ist wie eine Erweiterung der Eigenschaft oder IssuerName der SubjectName 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]
Die folgenden Feldlängenbeschränkungen gelten:
| Feld | Längenbeschränkung |
|---|---|
| Ländercode | 2 Zeichen |
| Organisation | Bis zu 64 Zeichen |
| OrganizationUnit | Bis zu 32 Zeichen |
| CommonName | Bis zu 64 Zeichen |
Die folgenden Richtlinien gelten:
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 korrekt formatierten Namen: [X500:/ C=US/ O=Microsoft/ OU=WGA/ CN=TedSt]
Konstruktoren
| Name | Beschreibung |
|---|---|
| X500DistinguishedName(AsnEncodedData) |
Initialisiert eine neue Instanz der X500DistinguishedName Klasse mithilfe des angegebenen AsnEncodedData Objekts. |
| X500DistinguishedName(Byte[]) |
Initialisiert eine neue Instanz der X500DistinguishedName Klasse mithilfe von Informationen aus dem angegebenen Bytearray. |
| X500DistinguishedName(ReadOnlySpan<Byte>) |
Initialisiert eine neue Instanz der X500DistinguishedName Klasse mithilfe von Informationen aus den bereitgestellten Daten. |
| X500DistinguishedName(String, X500DistinguishedNameFlags) |
Initialisiert eine neue Instanz der Klasse mithilfe der X500DistinguishedName angegebenen Zeichenfolge und X500DistinguishedNameFlags kennzeichnung. |
| X500DistinguishedName(String) |
Initialisiert eine neue Instanz der X500DistinguishedName Klasse mithilfe von Informationen aus der angegebenen Zeichenfolge. |
| X500DistinguishedName(X500DistinguishedName) |
Initialisiert eine neue Instanz der X500DistinguishedName Klasse mithilfe des angegebenen X500DistinguishedName Objekts. |
Eigenschaften
| Name | Beschreibung |
|---|---|
| Name |
Ruft den durch Trennzeichen getrennten Distinguished Name von einem X500-Zertifikat ab. |
| Oid |
Dient zum Abrufen oder Festlegen des Oid Werts für ein AsnEncodedData Objekt. (Geerbt von AsnEncodedData) |
| RawData |
Ruft ab oder legt die abstrakte Syntax Notation One (ASN.1)-codierte Daten in einem Bytearray dargestellt. (Geerbt von AsnEncodedData) |
Methoden
| Name | Beschreibung |
|---|---|
| CopyFrom(AsnEncodedData) |
Kopiert Informationen aus einem AsnEncodedData Objekt. (Geerbt von AsnEncodedData) |
| Decode(X500DistinguishedNameFlags) |
Decodiert einen distinguishierten Namen mithilfe der durch den |
| EnumerateRelativeDistinguishedNames(Boolean) |
Iterates over the RelativeDistinguishedName values within this distinguished name value. |
| Equals(Object) |
Bestimmt, ob das angegebene Objekt dem aktuellen Objekt entspricht. (Geerbt von Object) |
| Format(Boolean) |
Gibt eine formatierte Version eines X500-Distinguished-Namens für das Drucken oder für die Ausgabe in ein Textfenster oder in eine Konsole zurück. |
| GetHashCode() |
Dient als Standardhashfunktion. (Geerbt von Object) |
| GetType() |
Ruft die Type der aktuellen Instanz ab. (Geerbt von Object) |
| MemberwiseClone() |
Erstellt eine flache Kopie der aktuellen Object. (Geerbt von Object) |
| ToString() |
Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt. (Geerbt von Object) |