X500DistinguishedNameFlags Перечисление
Определение
Важно!
Некоторые сведения относятся к предварительной версии продукта, в которую до выпуска могут быть внесены существенные изменения. Майкрософт не предоставляет никаких гарантий, явных или подразумеваемых, относительно приведенных здесь сведений.
Задает характеристики различающегося имени, соответствующего стандарту X.500.
Это перечисление поддерживает побитовую комбинацию значений его членов.
public enum class X500DistinguishedNameFlags
[System.Flags]
public enum X500DistinguishedNameFlags
[<System.Flags>]
type X500DistinguishedNameFlags =
Public Enum 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
.
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
Комментарии
Это перечисление используется с классом для X500DistinguishedName обозначения специальных символов, содержащихся в различаемом имени.
Несколько значений являются взаимоисключающими в этом перечислении; используйте только одно из этих значений, чтобы определить специальные характеристики различающегося имени X.500. Например, укажите только одно из значений UseCommas
, UseNewLines
и UseSemicolons
. Можно также указать или UseT61Encoding
UseUTF8Encoding
.