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

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


CryptoConfig Класс

Определение

Обращается к сведениям о криптографической конфигурации.

C#
[System.Runtime.Versioning.UnsupportedOSPlatform("browser")]
public class CryptoConfig
C#
public class CryptoConfig
C#
[System.Runtime.InteropServices.ComVisible(true)]
public class CryptoConfig
Наследование
CryptoConfig
Атрибуты

Примеры

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

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

class Members
{
    static void Main(string[] args)
    {
        // Create a CryptoConfig object to store configuration information.
        CryptoConfig cryptoConfig = new CryptoConfig();

        // Retrieve the class path for CryptoConfig.
        string classDescription = cryptoConfig.ToString();

        // Create a new SHA1 provider.
        // This example uses the SHA1 algorithm.
        // Due to collision problems with SHA1, Microsoft recommends SHA256 or better.
        SHA1CryptoServiceProvider SHA1alg = 
            (SHA1CryptoServiceProvider)CryptoConfig.CreateFromName("SHA1");

        // Create an RSAParameters with the TestContainer key container.
        CspParameters parameters = new CspParameters();
        parameters.KeyContainerName = "TestContainer";
        Object[] argsArray = new Object[] {parameters};

        // Instantiate the RSA provider instance accessing the TestContainer
        // key container.
        RSA rsa = (RSA)
            CryptoConfig.CreateFromName("RSA",argsArray);

        // Use the MapNameToOID method to get an object identifier  
        // (OID) from the string name of the SHA1 algorithm.
        // This example uses the SHA1 algorithm.
        // Due to collision problems with SHA1, Microsoft recommends SHA256 or better.
        string sha1Oid = CryptoConfig.MapNameToOID("SHA1");

        // Encode the specified object identifier.
        // This example uses the SHA1 algorithm.
        // Due to collision problems with SHA1, Microsoft recommends SHA256 or better.
        byte[] encodedMessage = CryptoConfig.EncodeOID(sha1Oid);

        // Display the results to the console.
        Console.WriteLine("** " + classDescription + " **");
        Console.WriteLine("Created an RSA provider " + 
            "with a KeyContainerName called " + parameters.KeyContainerName +
            ".");
        Console.WriteLine("Object identifier from the SHA1 name:" + sha1Oid);
        Console.WriteLine("The object identifier encoded: " + 
            System.Text.Encoding.ASCII.GetString(encodedMessage));
        Console.WriteLine("This sample completed successfully; " +
            "press Enter to exit.");
        Console.ReadLine();
    }
}
//
// This sample produces the following output:
//
// ** System.Security.Cryptography.CryptoConfig **
// Created an RSA provider with a KeyContainerName called TestContainer.
// Object identifier from the SHA1 name:1.3.14.3.2.26
// The object identifier encoded: HH*((*H9
// This sample completed successfully; press Enter to exit.

Комментарии

В следующей таблице показаны простые имена, распознаваемые этим классом, и реализации алгоритма по умолчанию, с которыми они сопоставляются. Кроме того, можно сопоставить другие реализации с этими именами, как описано в разделе Сопоставление имен алгоритмов с классами шифрования.

Простое имя Реализация алгоритма
3DES, Triple DES, TripleDES, System.Security.Cryptography.TripleDES TripleDESCryptoServiceProvider
AES, System.Security.Cryptography.AesCryptoServiceProvider AesCryptoServiceProvider
AesManaged, System.Security.Cryptography.AesManaged AesManaged
System.Security.Cryptography.AsymmetricAlgorithm RSACryptoServiceProvider
DES, System.Security.Cryptography.DES DESCryptoServiceProvider
DSA, System.Security.Cryptography.DSA DSACryptoServiceProvider
ECDH, ECDiffieHellman, ECDiffieHellmanCng, System.Security.Cryptography.ECDiffieHellmanCng ECDiffieHellmanCng
ECDsa, ECDsaCng, System.Security.Cryptography.ECDsaCng ECDsaCng
System.Security.Cryptography.HashAlgorithm SHA1CryptoServiceProvider
HMAC, System.Security.Cryptography.HMAC HMACSHA1
HMACMD5, System.Security.Cryptography.HMACMD5 HMACMD5
HMACRIPEMD160, System.Security.Cryptography.HMACRIPEMD160 HMACRIPEMD160
HMACSHA1, System.Security.Cryptography.HMACSHA1 HMACSHA1
HMACSHA256, System.Security.Cryptography.HMACSHA256 HMACSHA256
HMACSHA384, System.Security.Cryptography.HMACSHA384 HMACSHA384
HMACSHA512, System.Security.Cryptography.HMACSHA512 HMACSHA512
System.Security.Cryptography.KeyedHashAlgorithm HMACSHA1
MACTripleDES, System.Security.Cryptography.MACTripleDES MACTripleDES
MD5, System.Security.Cryptography.MD5 MD5CryptoServiceProvider
System.Security.Cryptography.MD5Cng MD5Cng
RandomNumberGenerator RNGCryptoServiceProvider
RC2, System.Security.Cryptography.RC2 RC2CryptoServiceProvider
Rijndael, System.Security.Cryptography.Rijndael RijndaelManaged
RIPEMD160, RIPEMD-160, System.Security.Cryptography.RIPEMD160Managed RIPEMD160Managed
RSA, System.Security.Cryptography.RSA RSACryptoServiceProvider
SHA, SHA1, System.Security.Cryptography.SHA1 SHA1CryptoServiceProvider
System.Security.Cryptography.SHA1Cng SHA1Cng
SHA256, SHA-256, System.Security.Cryptography.SHA256 SHA256Managed
System.Security.Cryptography.SHA256Cng SHA256Cng
System.Security.Cryptography.SHA256CryptoServiceProvider SHA256CryptoServiceProvider
SHA384, SHA-384, System.Security.Cryptography.SHA384 SHA384Managed
System.Security.Cryptography.SHA384Cng SHA384Cng
System.Security.Cryptography.SHA384CryptoServiceProvider SHA384CryptoServiceProvider
SHA512, SHA-512, System.Security.Cryptography.SHA512 SHA512Managed
System.Security.Cryptography.SHA512Cng SHA512Cng
System.Security.Cryptography.SHA512CryptoServiceProvider SHA512CryptoServiceProvider
System.Security.Cryptography.SymmetricAlgorithm RijndaelManaged

Конструкторы

CryptoConfig()

Инициализирует новый экземпляр класса CryptoConfig.

Свойства

AllowOnlyFipsAlgorithms

Указывает, следует ли среде выполнения использовать политику для создания только алгоритмов, удовлетворяющих стандартам FIPS.

Методы

AddAlgorithm(Type, String[])

Добавляет к сопоставлениям алгоритмов набор имен, который следует использовать для текущего домена приложения.

AddOID(String, String[])

Добавляет к сопоставлениям идентификатора объекта набор имен, который следует использовать для текущего домена приложения.

CreateFromName(String)

Создает новый экземпляр заданного криптографического объекта.

CreateFromName(String, Object[])

Создает новый экземпляр заданного криптографического объекта с заданными аргументами.

EncodeOID(String)
Устаревшие..

Кодирует заданный идентификатор объекта.

Equals(Object)

Определяет, равен ли указанный объект текущему объекту.

(Унаследовано от Object)
GetHashCode()

Служит хэш-функцией по умолчанию.

(Унаследовано от Object)
GetType()

Возвращает объект Type для текущего экземпляра.

(Унаследовано от Object)
MapNameToOID(String)

Получает идентификатор объекта-алгоритма, соответствующего заданному простому имени.

MemberwiseClone()

Создает неполную копию текущего объекта Object.

(Унаследовано от Object)
ToString()

Возвращает строку, представляющую текущий объект.

(Унаследовано от Object)

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

См. также раздел