Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
113 / 100 / 68
Регистрация: 21.04.2014
Сообщений: 1,420

Объяснение работы с шифрованием

20.11.2019, 13:31. Показов 396. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.
Ради интереса захотел сделать простой шифровщик/дешифровщик сообщений. По примерам легко смог создать нечто подобное:
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
private void btnCreateCipher_Click ( object sender, EventArgs e )
        {
            rtbResult.Text = Convert.ToBase64String ( Encrypt ( Encoding.UTF8.GetBytes ( rtbValue.Text ), rtbKey.Text ) );
        }
 
        private void btnDecrypt_Click ( object sender, EventArgs e )
        {
            rtbResult.Text = Decrypt ( rtbValue.Text, rtbKey.Text );
        }
 
        private static byte [] Encrypt ( byte [] key, string value )
        {
            SymmetricAlgorithm Sa = Rijndael.Create ( );
            ICryptoTransform Ct = Sa.CreateEncryptor ( ( new PasswordDeriveBytes ( value, null ) ).GetBytes ( 16 ), new byte [ 16 ] );
            MemoryStream Ms = new MemoryStream ( );
            CryptoStream Cs = new CryptoStream ( Ms, Ct, CryptoStreamMode.Write );
            Cs.Write ( key, 0, key.Length );
            Cs.FlushFinalBlock ( );
            byte[] Result = Ms.ToArray ( );
            Ms.Close ( );
            Ms.Dispose ( );
            Cs.Close ( );
            Cs.Dispose ( );
            Ct.Dispose ( );
            return Result;
        }
 
        private static string Decrypt ( string str, string keyCrypt )
        {
            string Result;
            try
            {
                CryptoStream Cs = InternalDecrypt ( Convert.FromBase64String ( str ), keyCrypt );
                StreamReader Sr = new StreamReader ( Cs );
                Result = Sr.ReadToEnd ( );
                Cs.Close ( );
                Cs.Dispose ( );
                Sr.Close ( );
                Sr.Dispose ( );
            }
            catch
            {
                return null;
            }
            return Result;
        }
 
        private static CryptoStream InternalDecrypt ( byte [] key, string value )
        {
            SymmetricAlgorithm sa = Rijndael.Create ( );
            ICryptoTransform ct = sa.CreateDecryptor ( ( new PasswordDeriveBytes ( value, null ) ).GetBytes ( 16 ), new byte [ 16 ] );
            MemoryStream ms = new MemoryStream ( key );
            return new CryptoStream ( ms, ct, CryptoStreamMode.Read );
        }
Работает. Да только вот не очень то я понял, что вообще написал и описание классов в MSDN не слишком сильно помогло... Прошу разъяснить мне как это всё работает. Вот что я понял (не факт, что правильно):

C#
1
2
SymmetricAlgorithm Sa = Rijndael.Create ( ); 
//Берём базовый класс SymmetricAlgorithm и выбираем его наследника (алгоритм шифрования), в данном случае Rijndael.
C#
1
2
ICryptoTransform Ct = Sa.CreateEncryptor ( ( new PasswordDeriveBytes ( value, null ) ).GetBytes ( 16 ), new byte [ 16 ] );
//Не понял эту строку толком, но видимо здесь указывается размер блока шифрования и у каждого алгоритма он свой
C#
1
2
CryptoStream Cs = new CryptoStream ( Ms, Ct, CryptoStreamMode.Write ); 
//Видимо здесь мы определяем отдельный поток для механизма шифрования, который требует другой отдельный поток MS... не понял =_=
C#
1
Cs.Write ( key, 0, key.Length ); //Передаём в поток шифрования ключ и смещение (в данном случае, нулевое)
C#
1
Cs.FlushFinalBlock ( ); // Видимо, стартуем процесс шифрования?
Поправьте что здесь не так и объясните, пожалуйста.

P.S. я ведь правильно понял из википедии, что расшифровка без ключа строки, зашифрованной Rijndael - это задача практически невыполнимая?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2019, 13:31
Ответы с готовыми решениями:

Объяснение работы оператора =>
Здравствуйте. Не могу понять как работает оператор =>. Нагуглить то про него оказалось не очень сложно, но из тех объяснений, что я...

Объяснение работы функции fft()
Функция fft() осуществляет быстрое преобразование Фурье. Правда, в качестве результата она выдает массив комплексных чисел, даже если...

Объяснение результата работы программы
В результате этой программы выведется 3303 3003 Нужно объяснить как получился этот ответ. program sss; Uses crt; var...

1
 Аватар для Enifan
1848 / 1190 / 501
Регистрация: 14.10.2018
Сообщений: 3,211
20.11.2019, 14:01
Цитата Сообщение от FaceHoof Посмотреть сообщение
простой шифровщик/дешифровщик
по правде говоря простой выглядит так (пример взят из Шилдта)
Кликните здесь для просмотра всего текста
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
// Применить поразрядный поразрядного оператора исключающее ИЛИ.
 
using System;
 
class Encode // Зашифровать
{
    static void Main()
    {
        char ch1 = 'H';
        char ch2 = 'i';
        char ch3 = '!';
        int key = 88;
 
        Console.WriteLine("Исходное сообщение: " + ch1 + ch2 + ch3);
 
        // Зашифровать сообщение.
        ch1 = (char)(ch1 ^ key);
        ch2 = (char)(ch2 ^ key);
        ch3 = (char)(ch3 ^ key);
 
        Console.WriteLine("Зашифрованное сообщение: " + ch1 + ch2 + ch3);
 
        // Расшифровать сообщение.
        ch1 = (char)(ch1 ^ key);
        ch2 = (char)(ch2 ^ key);
        ch3 = (char)(ch3 ^ key);
 
        Console.WriteLine("Расшифрованное сообщение: " + ch1 + ch2 + ch3);
 
        Console.ReadKey();
    }
}

Насчет вашего - пока сказать нечего, надо смотреть документации, понимать что делает тот или иной класс / интерфейс / метод. Будет время - гляну.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
20.11.2019, 14:01
Помогаю со студенческими работами здесь

Рекурсия, нужно объяснение работы кода
Объясните пожалуйста как работает здесь рекурсия: #include <iostream> void func(int num); int main(void) { func(5); ...

Макрос для работы с матрицей, нужно объяснение
Подскажите, что происходит в этом макросе, как он работает, очень нужно!!! Заранее Спасибо. ; Макрос для операции над отдельным...

Нужно объяснение работы функции zip в этой задаче
Всем привет! Изучаю haskell на примере задач из проекта Эйлера. Есть задача 112 о прыгучих числах (ссылка...

Объяснение работы метода, сравнивающего значения времени в двух input.
Здравствуйте! Нужно разобраться в чужом коде $.validator.addMethod('timeGreaterThan', function (value, element, param) { return...

Напишите, пожалуйста объяснение к каждой строчке кода. Если можно, и объяснение некоторых функций
#include <stdlib.h> #include <stdio.h> void random(int * a, int size) { while(size--) *a++ = rand() % 9 + 1; } ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru