X500DistinguishedName Třída
Definice
Důležité
Některé informace platí pro předběžně vydaný produkt, který se může zásadně změnit, než ho výrobce nebo autor vydá. Microsoft neposkytuje žádné záruky, výslovné ani předpokládané, týkající se zde uváděných informací.
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
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 |
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) |