Нужно подписать строку подписью RSASSA-PKCS1-v1_5 в С#

У меня есть строка с сообщением и закрытым ключом. Мне нужно написать код C#, который может подписать эту строку подписью RSASSA-PKCS1-v1_5.

Есть ли у вас какие-либо намеки или предложения относительно того, где я должен начать искать, чтобы выполнить это? Существуют ли существующие API в .NET или в доступных библиотеках для этого?


person Esben Jensen    schedule 11.05.2015    source источник
comment
Немного перефразирую вопрос.   -  person reuben    schedule 14.05.2015


Ответы (1)


Это пример того, как это сделать, вы можете реализовать его с необходимыми изменениями в вашем коде (пример взят из сайт MSDN:

using System;
using System.Security.Cryptography;
using Org.BouncyCastle.OpenSsl;
using Org.BouncyCastle.Crypto;
using Org.BouncyCastle.Security;
using Org.BouncyCastle.Crypto.Parameters;

class RSASample
{
   const string PubKeyFile = @"c:\encrypt\fileWithKey.pem";
   const string keyName = "Key01";
   CspParameters cspp = new CspParameters();
   RSAParameters RSAKeyInfo = new RSAParameters();

   Org.BouncyCastle.Utilities.IO.Pem.PemObject po = null;
   using (StreamReader sr = new StreamReader(PubKeyFile))
   {
        Org.BouncyCastle.OpenSsl.PemReader pr = new Org.BouncyCastle.OpenSsl.PemReader(reader);
        po = pr.ReadPemObject();
   }

   RSAKeyInfo.Modulus = po.Content;
   cspp.KeyContainerName = keyName;
   try
   {
        //Create a new instance of RSACryptoServiceProvider. 
        using (RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(cspp))
        {
             rsa.PersistKeyInCsp = true;
             rsa.ImportParameters(RSAKeyInfo);
             //The hash to sign. 
             byte[] hash;
             using (SHA256 sha256 = SHA256.Create())
             {
                  byte[] data = new byte[] { 59, 4, 248, 102, 77, 97, 142, 201, 210, 12, 224, 93, 25, 41, 100, 197, 213, 134, 130, 135 };
                  hash = sha256.ComputeHash(data);
             }


             //Create an RSASignatureFormatter object and pass it the  
             //RSACryptoServiceProvider to transfer the key information.
             RSAPKCS1SignatureFormatter RSAFormatter = new RSAPKCS1SignatureFormatter(rsa);

             //Set the hash algorithm to SHA256.
             RSAFormatter.SetHashAlgorithm("SHA256");

             //Create a signature for HashValue and return it. 
             byte[] SignedHash = RSAFormatter.CreateSignature(hash);
             }
    }
    catch (CryptographicException e)
    {
         Console.WriteLine(e.Message);
    }
}
person israel altar    schedule 11.05.2015
comment
Спасибо, но куда делся мой закрытый ключ? - person Esben Jensen; 11.05.2015
comment
Закрытый ключ в pem-файле - person Esben Jensen; 12.05.2015
comment
Этот код выполняет работу на Ruby, но мне нужно сделать это на С#. key = OpenSSL::PKey::RSA.new(pemstring) key.sign(OpenSSL::Digest.new('sha256'), body).unpack('H*').first - person Esben Jensen; 12.05.2015
comment
Спасибо попробую сегодня позже - person Esben Jensen; 12.05.2015
comment
Но вы не загружаете PubKeyFile - person Esben Jensen; 12.05.2015