powered by simpleCommunicator - 2.0.36     © 2025 Programmizd 02
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / RSA-шифрование
3 сообщений из 3, страница 1 из 1
RSA-шифрование
    #40010640
ptybn84.07
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Добрый вечер, форумчане.
Мудрое куроводство поставило задачу организовать работу между 2 смежных модулей следующим образом - строку данных json шифруем публичным ключом, а ответ расшифровываем приватным.
При этом в качестве публичного выдали .pub-файл, в котором есть только блок BEGIN PUBLIC KEY/END PUBLIC KEY, а в качестве приватного - .pem-файл с блоком BEGIN RSA PRIVATE KEY/END RSA PRIVATE KEY, в который помимо самого ключа впихнуты строки Proc-Type и DEK-Info
Я не нашел реализации шифрования при таких исходных данных.
Для pfx-файла примеры есть, для сертификатов .cer.
А для таких исходных - 0.
Вопрос - есть ли реализация подобного механизма в таких условиях?
...
Рейтинг: 0 / 0
RSA-шифрование
    #40010710
НеофитSQL
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
ptybn84.07,


Посмотрите тут, это то что вы ищете?: https://foxlearn.com/windows-forms/encryption-and-decryption-using-rsa-in-csharp-360.html
Если у вас

Не забудьте что правильное использование RSA не предусматривает шифрование юзерских данных напрямик.
...
Рейтинг: 0 / 0
RSA-шифрование
    #40010779
Сон Веры Павловны
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
ptybn84.07,

В FCL из коробки нет средств для работы с pem-файлами, это умеет BouncyCastle . Файл с открытым ключом (pub) в принципе не нужен - закрытый ключ всегда содержит открытый ключ.
А дальше как-то так:
Код: c#
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
48.
49.
50.
51.
52.
53.
54.
55.
56.
57.
58.
59.
60.
61.
62.
63.
64.
65.
66.
67.
68.
69.
70.
71.
72.
73.
74.
75.
76.
77.
78.
79.
80.
81.
82.
83.
84.
85.
86.
87.
88.
public class Program
{
  public static void Main(string[] args)
  {
    CreatePem("Alice");
    CreatePem("Bob");
    using (var alice = new RijndaelSite("Alice"))
    using (var bob = new RijndaelSite("Bob"))
    {
      alice.Send(bob, "Мама мыла раму");
      bob.Send(alice, "Рыбий жир победит постмодернизм.");
    }
  }

  static void CreatePem(string name)
  {
    var keyPair = DotNetUtilities.GetRsaKeyPair(new RSACryptoServiceProvider().ExportParameters(true));
    using (var fs = File.Create(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, $"{name}.pem")))
    using (var tw = new StreamWriter(fs))
    {
      var pw = new Org.BouncyCastle.OpenSsl.PemWriter(tw);
      pw.WriteObject(keyPair.Private);
    }
  }
}

class RijndaelSite: CryptoSite<RijndaelManaged>
{
  public RijndaelSite(string name) : base(name)
  {
  }
}

class CryptoSite<T> : IDisposable where T: SymmetricAlgorithm, new()
{
  readonly RSA _rsaKey;
  public byte[] PublicKey { get; }
  public string Name { get; }
  public CryptoSite(string name)
  {
    if (string.IsNullOrEmpty(name))
      throw new ArgumentException(nameof(name));
    Name = name;
    AsymmetricCipherKeyPair keyPair; 
    using (var reader = File.OpenText(Path.Combine(AppDomain.CurrentDomain.BaseDirectory, $"{name}.pem")))
      keyPair = (AsymmetricCipherKeyPair) new Org.BouncyCastle.OpenSsl.PemReader(reader).ReadObject();
    _rsaKey = DotNetUtilities.ToRSA((RsaPrivateCrtKeyParameters) keyPair.Private);
    PublicKey = ((RSACryptoServiceProvider)_rsaKey).ExportCspBlob(false);
  }

  public void Send(CryptoSite<T> cryptoSite, string plainText)
  {
    using(var provider = new RSACryptoServiceProvider())
    using (var sa = new T())
    {
      provider.ImportCspBlob(cryptoSite.PublicKey);
      var keyFormatter = new RSAPKCS1KeyExchangeFormatter(provider);
      using (var ciphertext = new MemoryStream())
      using (var cs = new CryptoStream(ciphertext, sa.CreateEncryptor(), CryptoStreamMode.Write))
      {
        var plaintextMessage = Encoding.UTF8.GetBytes(plainText);
        cs.Write(plaintextMessage, 0, plaintextMessage.Length);
        cs.Close();
        Console.WriteLine("{0} send to {1} message {2}", Name, cryptoSite.Name, plainText);
        cryptoSite.Receive(sa.IV, keyFormatter.CreateKeyExchange(sa.Key, typeof(T)), ciphertext.ToArray());
      }
    }
  }

  public void Receive(byte[] iv, byte[] encryptedSessionKey, byte[] encryptedMessage)
  {
    using (var sa = new T())
    {
      sa.IV = iv;
      var keyDeformatter = new RSAPKCS1KeyExchangeDeformatter(_rsaKey);
      sa.Key = keyDeformatter.DecryptKeyExchange(encryptedSessionKey);
      using (var plaintext = new MemoryStream())
      using (var cs = new CryptoStream(plaintext, sa.CreateDecryptor(), CryptoStreamMode.Write))
      {
        cs.Write(encryptedMessage, 0, encryptedMessage.Length);
        cs.Close();
        Console.WriteLine("{0} received: {1}", Name, Encoding.UTF8.GetString(plaintext.ToArray()));
      }
    }
  }

  public void Dispose() => _rsaKey.Dispose();
}
...
Рейтинг: 0 / 0
3 сообщений из 3, страница 1 из 1
Форумы / WinForms, .Net Framework [игнор отключен] [закрыт для гостей] / RSA-шифрование
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]