X500DistinguishedName Classe

Definizione

Rappresenta il nome distinto di un certificato X509. La classe non può essere ereditata.

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
Ereditarietà
X500DistinguishedName

Esempio

Nell'esempio di codice seguente viene illustrato l'utilizzo della classe X500DistinguishedName.

#using <System.dll>
#using <system.security.dll>

using namespace System;
using namespace System::Security::Cryptography;
using namespace System::Security::Permissions;
using namespace System::IO;
using namespace System::Security::Cryptography::X509Certificates;
int main()
{
   try
   {
      X509Store ^ store = gcnew X509Store( "MY",StoreLocation::CurrentUser );
      store->Open( static_cast<OpenFlags>(OpenFlags::ReadOnly | OpenFlags::OpenExistingOnly) );
      X509Certificate2Collection ^ collection = dynamic_cast<X509Certificate2Collection^>(store->Certificates);
      X509Certificate2Collection ^ fcollection = dynamic_cast<X509Certificate2Collection^>(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: {0}{1}", scollection->Count, Environment::NewLine );
      System::Collections::IEnumerator^ myEnum = scollection->GetEnumerator();
      while ( myEnum->MoveNext() )
      {
         X509Certificate2 ^ x509 = safe_cast<X509Certificate2 ^>(myEnum->Current);
         X500DistinguishedName ^ dname = gcnew X500DistinguishedName( x509->SubjectName );
         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." );
   }

}
using System;
using System.Security.Cryptography;
using System.Security.Permissions;
using System.IO;
using System.Security.Cryptography.X509Certificates;

class X500Sample
{
    static void Main()
    {
        try
        {
            X509Store store = new X509Store("MY", StoreLocation.CurrentUser);
            store.Open(OpenFlags.ReadOnly | OpenFlags.OpenExistingOnly);
            X509Certificate2Collection collection = (X509Certificate2Collection)store.Certificates;
            X509Certificate2Collection fcollection = (X509Certificate2Collection)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: {0}{1}", scollection.Count, Environment.NewLine);
            foreach (X509Certificate2 x509 in scollection)
            {
                X500DistinguishedName dname = new X500DistinguishedName(x509.SubjectName);
                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
Imports System.Security.Permissions
Imports System.IO
Imports System.Security.Cryptography.X509Certificates



Class X500Sample
   Shared 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 = CType(store.Certificates, X509Certificate2Collection)
         Dim fcollection As X509Certificate2Collection = CType(collection.Find(X509FindType.FindByTimeValid, DateTime.Now, False), X509Certificate2Collection)
         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)
     msg = "Number of certificates: " & scollection.Count & Environment.NewLine
     MsgBox(msg)
         Dim x509 As X509Certificate2
         For Each x509 In  scollection
            Dim dname As New X500DistinguishedName(x509.SubjectName)
        msg = "X500DistinguishedName: " & dname.Name & Environment.NewLine
     MsgBox(msg)
            x509.Reset()
         Next x509
         store.Close()
     Catch e As Exception
            msg = "Error: Information could not be written out for this certificate."
            MsgBox(msg)
      End Try
   End Sub
End Class

Commenti

Questa classe è simile a un'estensione alla SubjectName proprietà o IssuerName , ovvero il nome della persona o dell'entità a cui viene emesso il certificato. X.500 è uno standard internazionale per i servizi directory distribuiti. Il nome distinto usa il formato seguente:

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

Si applicano i limiti di lunghezza del campo seguenti:

Campo Limite di lunghezza
CountryCode 2 caratteri
Organization Fino a 64 caratteri
OrganizationUnit Fino a 32 caratteri
CommonName Fino a 64 caratteri

Vengono applicate le linee guida riportate di seguito:

  • I valori dei campi possono essere maiuscoli o minuscoli.

  • I delimitatori sono segni di barra (/) e devono essere visualizzati prima del primo valore e tra i valori successivi.

  • I delimitatori possono essere seguiti da uno spazio.

Di seguito è riportato un esempio di nome formattato correttamente: [X500:/ C=US/ O=Microsoft/ OU=WGA/ CN=TedSt]

Costruttori

X500DistinguishedName(AsnEncodedData)

Inizializza una nuova istanza della classe X500DistinguishedName usando l'oggetto AsnEncodedData specificato.

X500DistinguishedName(Byte[])

Inizializza una nuova istanza della classe X500DistinguishedName utilizzando le informazioni derivate dalla matrice di byte specificata.

X500DistinguishedName(ReadOnlySpan<Byte>)

Inizializza una nuova istanza della classe X500DistinguishedName usando le informazioni derivate dai dati specificati.

X500DistinguishedName(String)

Inizializza una nuova istanza della classe X500DistinguishedName utilizzando le informazioni derivate dalla stringa specificata.

X500DistinguishedName(String, X500DistinguishedNameFlags)

Inizializza una nuova istanza della classe X500DistinguishedName utilizzando la stringa specificata e il flag X500DistinguishedNameFlags.

X500DistinguishedName(X500DistinguishedName)

Inizializza una nuova istanza della classe X500DistinguishedName usando l'oggetto X500DistinguishedName specificato.

Proprietà

Name

Ottiene il nome distinto delimitato da virgole da un certificato X500.

Oid

Ottiene o imposta il valore Oid per un oggetto AsnEncodedData.

(Ereditato da AsnEncodedData)
RawData

Ottiene o imposta i dati con codifica ASN.1 rappresentati in una matrice di byte.

(Ereditato da AsnEncodedData)

Metodi

CopyFrom(AsnEncodedData)

Copia le informazioni da un oggetto AsnEncodedData.

(Ereditato da AsnEncodedData)
Decode(X500DistinguishedNameFlags)

Decodifica un nome distinto utilizzando le caratteristiche specificate dal parametro flag.

Equals(Object)

Determina se l'oggetto specificato è uguale all'oggetto corrente.

(Ereditato da Object)
Format(Boolean)

Restituisce una versione formattata di un nome distinto X500 per la visualizzazione o l'output in una finestra di testo o una console.

GetHashCode()

Funge da funzione hash predefinita.

(Ereditato da Object)
GetType()

Ottiene l'oggetto Type dell'istanza corrente.

(Ereditato da Object)
MemberwiseClone()

Crea una copia superficiale dell'oggetto Object corrente.

(Ereditato da Object)
ToString()

Restituisce una stringa che rappresenta l'oggetto corrente.

(Ereditato da Object)

Si applica a