X509ChainPolicy Classe

Definizione

Rappresenta i criteri di catena da applicare durante la compilazione di una catena di certificati X509. La classe non può essere ereditata.

C#
public sealed class X509ChainPolicy
Ereditarietà
X509ChainPolicy

Esempio

Nell'esempio seguente viene aperto l'archivio certificati personale dell'utente corrente, che consente all'utente di selezionare un certificato, quindi di scrivere le informazioni sul certificato e sulla catena di certificati nella console. L'output dipende dal certificato selezionato.

C#
using System;
using System.Security.Cryptography;
using System.Security.Cryptography.X509Certificates;
using System.IO;

class TestX509Chain
{
    static void Main(string[] args)
    {
        //Create new X509 store from local certificate store.
        X509Store store = new X509Store("MY", StoreLocation.CurrentUser);
        store.Open(OpenFlags.OpenExistingOnly | OpenFlags.ReadWrite);

        //Output store information.
        Console.WriteLine ("Store Information");
        Console.WriteLine ("Number of certificates in the store: {0}", store.Certificates.Count);
        Console.WriteLine ("Store location: {0}", store.Location);
        Console.WriteLine ("Store name: {0} {1}", store.Name, Environment.NewLine);
    
        //Put certificates from the store into a collection so user can select one.
        X509Certificate2Collection fcollection = (X509Certificate2Collection)store.Certificates;
        X509Certificate2Collection collection = X509Certificate2UI.SelectFromCollection(fcollection, "Select an X509 Certificate", "Choose a certificate to examine.", X509SelectionFlag.SingleSelection);
        X509Certificate2 certificate = collection[0];
        X509Certificate2UI.DisplayCertificate(certificate);

        //Output chain information of the selected certificate.
        X509Chain ch = new X509Chain();
        ch.ChainPolicy.RevocationMode = X509RevocationMode.Online;
        ch.Build (certificate);
        Console.WriteLine ("Chain Information");
        Console.WriteLine ("Chain revocation flag: {0}", ch.ChainPolicy.RevocationFlag);
        Console.WriteLine ("Chain revocation mode: {0}", ch.ChainPolicy.RevocationMode);
        Console.WriteLine ("Chain verification flag: {0}", ch.ChainPolicy.VerificationFlags);
        Console.WriteLine ("Chain verification time: {0}", ch.ChainPolicy.VerificationTime);
        Console.WriteLine ("Chain status length: {0}", ch.ChainStatus.Length);
        Console.WriteLine ("Chain application policy count: {0}", ch.ChainPolicy.ApplicationPolicy.Count);
        Console.WriteLine ("Chain certificate policy count: {0} {1}", ch.ChainPolicy.CertificatePolicy.Count, Environment.NewLine);

        //Output chain element information.
        Console.WriteLine ("Chain Element Information");
        Console.WriteLine ("Number of chain elements: {0}", ch.ChainElements.Count);
        Console.WriteLine ("Chain elements synchronized? {0} {1}", ch.ChainElements.IsSynchronized, Environment.NewLine);
    
        foreach (X509ChainElement element in ch.ChainElements)
        {
            Console.WriteLine ("Element issuer name: {0}", element.Certificate.Issuer);
            Console.WriteLine ("Element certificate valid until: {0}", element.Certificate.NotAfter);
            Console.WriteLine ("Element certificate is valid: {0}", element.Certificate.Verify ());
            Console.WriteLine ("Element error status length: {0}", element.ChainElementStatus.Length);
            Console.WriteLine ("Element information: {0}", element.Information);
            Console.WriteLine ("Number of element extensions: {0}{1}", element.Certificate.Extensions.Count, Environment.NewLine);

            if (ch.ChainStatus.Length > 1)
            {
                for (int index = 0; index < element.ChainElementStatus.Length; index++)
                {
                    Console.WriteLine (element.ChainElementStatus[index].Status);
                    Console.WriteLine (element.ChainElementStatus[index].StatusInformation);
                }
            }
        }
        store.Close();
    }
}

Commenti

Ogni X509Certificate2 oggetto può avere una X509ChainPolicy proprietà che specifica i criteri da usare nel processo di verifica. Si noti che solo X509Certificate2 gli oggetti possono costruire un X509ChainPolicy oggetto .

Costruttori

X509ChainPolicy()

Inizializza una nuova istanza della classe X509ChainPolicy.

Proprietà

ApplicationPolicy

Ottiene una raccolta di identificatori di oggetti (OID) che specificano quali criteri di applicazione o utilizzi chiavi avanzati (EKU) deve supportare il certificato.

CertificatePolicy

Ottiene una raccolta di identificatori di oggetti (OID) che specificano quali criteri di certificato deve supportare il certificato.

CustomTrustStore

Rappresenta una raccolta di certificati che sostituisce il trust del certificato predefinito.

DisableCertificateDownloads

Ottiene o imposta un valore che indica se il motore della catena può usare l'estensione AIA (Authority Information Access) per individuare i certificati sconosciuti dell'autorità di certificazione.

ExtraStore

Ottiene un oggetto che rappresenta una raccolta aggiuntiva di certificati che possono essere cercati dal modulo di concatenazione durante la convalida di una catena di certificati.

RevocationFlag

Ottiene o imposta i valori per i flag di revoca X509.

RevocationMode

Ottiene o imposta i valori per la modalità di revoca dei certificati X509.

TrustMode

Modalità che determina il trust radice per la creazione della catena di certificati.

UrlRetrievalTimeout

Ottiene o imposta il periodo di tempo massimo da dedicare durante la verifica della revoca in linea o durante il download del CRL (Certificate Revocation List, elenco certificati revocati). Il valore Zero significa che non sono previsti limiti.

VerificationFlags

Ottiene i flag di verifica per il certificato.

VerificationTime

Ottiene o imposta il tempo per la convalida della catena.

VerificationTimeIgnored

Ottiene o imposta un valore che indica se la convalida della catena deve usare VerificationTime o l'ora di sistema corrente durante la compilazione di una catena di certificati X.509.

Metodi

Clone()

Crea una nuova istanza di criteri della catena con le stesse impostazioni di questa istanza.

Equals(Object)

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

(Ereditato da Object)
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)
Reset()

Ripristina i valori predefiniti dei membri X509ChainPolicy.

ToString()

Restituisce una stringa che rappresenta l'oggetto corrente.

(Ereditato da Object)

Si applica a

Prodotto Versioni
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9, 10
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.3, 1.4, 1.6, 2.0, 2.1