Прочитать на английском

Поделиться через


X500DistinguishedNameFlags Перечисление

Определение

Задает характеристики различающегося имени, соответствующего стандарту X.500.

Это перечисление поддерживает побитовую комбинацию значений его членов.

C#
[System.Flags]
public enum X500DistinguishedNameFlags
Наследование
X500DistinguishedNameFlags
Атрибуты

Поля

Имя Значение Описание
DoNotUsePlusSign 32

В различающемся имени не используется знак «плюс».

DoNotUseQuotes 64

В различающемся имени не используются кавычки.

ForceUTF8Encoding 16384

Обеспечивает принудительную кодировку определенных ключей X.500 в различающемся имени как строк UTF-8, а не печатных строк Юникода. Дополнительную информацию и список затрагиваемых ключей X.500 см. в описании перечисления X500NameFlags.

None 0

В различающемся имени отсутствуют особые параметры.

Reversed 1

Различающееся имя записывается в обратном порядке.

UseCommas 128

В различающемся имени используются запятые.

UseNewLines 256

В различающемся имени используется символ новой строки.

UseSemicolons 16

В различающемся имени используются точки с запятой.

UseT61Encoding 8192

В различающемся имени используется кодировка T61.

UseUTF8Encoding 4096

В различающемся имени используется кодировка UTF8 вместо кодировки символов Юникода.

Примеры

В следующем примере кода показано, как использовать перечисление X500DistinguishedNameFlags .

C#
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.");
        }
    }
}

Комментарии

Это перечисление используется с классом для X500DistinguishedName обозначения специальных символов, содержащихся в различаемом имени.

Несколько значений являются взаимоисключающими в этом перечислении; используйте только одно из этих значений, чтобы определить специальные характеристики различающегося имени X.500. Например, укажите только одно из значений UseCommas, UseNewLines и UseSemicolons . Можно также указать или UseT61EncodingUseUTF8Encoding.

Применяется к

Продукт Версии
.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
.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