Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.53/15: Рейтинг темы: голосов - 15, средняя оценка - 4.53
2 / 2 / 1
Регистрация: 04.12.2012
Сообщений: 202

Реализация алгоритма RC4 - разобрать код

23.05.2014, 09:21. Показов 3242. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Помогите пожалуйста разобраться с блоком Алгоритм ключевого расписания
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
using System;
using System.IO;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace ConsoleApplication74
{
class rc4
{
static void Print(byte[] b)
{
for (int i = 0; i < b.GetLength(0); i++)
{
Console.Write(b[i]);
}
Console.WriteLine();
}
static void Main(string[] args)
{
Console.Write("Введите ключ: ");
byte[] key = ASCIIEncoding.ASCII.GetBytes(Console.ReadLine());//GetBytes кодирует набор символов в набор байтов
 
RC4 encoder = new RC4(key);
Console.Write("Введите строку, которую необходимо зашифровать: ");
string testString = Console.ReadLine();
byte[] testBytes = ASCIIEncoding.ASCII.GetBytes(testString);//GetBytes 
кодирует набор символов в набор байтов
byte[] result = encoder.Encode(testBytes, testBytes.Length);//преобразует набор символов в послед-ть байтов
Console.Write("Результат: ");
Print(result);
Console.WriteLine();
 
RC4 decoder = new RC4(key);////обращение
byte[] decryptedBytes = decoder.Decode(result, result.Length);//преобр. послед-ть байтов в набор символов
string decryptedString = ASCIIEncoding.ASCII.GetString(decryptedBytes);
Console.WriteLine("После того как подставили ключ: " + decryptedString);
Console.ReadLine();
}
public class RC4
{
public static void Swap(ref byte a, ref byte b)
{
byte c = a;
a = b;
b = c;
}
public static void Swap(ref int a, ref int b)
{
int c = a;
a = b;
b = c;
}
byte[] S = new byte[256];
int x = 0;
int y = 0;
public RC4(byte[] key)
{
init(key);
}
 
// Алгоритм ключевого расписания 
private void init(byte[] key)
{
int keyLength = key.Length;
 
for (int i = 0; i < 256; i++)
{
S[i] = (byte)i;
}
int j = 0;
for (int i = 0; i < 256; i++)
{
j = (j + S[i] + key[i % keyLength]) % 256;
Swap(ref S[i], ref S[j]);
}
}
public byte[] Encode(byte[] dataB, int size)
{
byte[] data = dataB.Take(size).ToArray();
 
byte[] cipher = new byte[data.Length];
for (int m = 0; m < data.Length; m++)
{
cipher[m] = (byte)(data[m] ^ keyItem());
}
return cipher;
}
public byte[] Decode(byte[] dataB, int size)
{
return Encode(dataB, size);
}
// Генератор псевдослучайной последовательности 
private byte keyItem()
{
x = (x + 1) % 256;
y = (y + S[x]) % 256;
Swap(ref x, ref y);
return S[(S[x] + S[y]) % 256];
}
}
}
 
}
Что за переменные j и i. Я так понимаю это счетчики, но что они хранят за что отвечают, что за хитрая формула. Везде пишут происходит скремблирование, и в цикле происходят вычисления обеспечивающие однократное использование элементов массива...
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.05.2014, 09:21
Ответы с готовыми решениями:

Реализация алгоритма RC4
Приветствую.Нужна простейшая реализация данного алгоритма.Может кто исходник кинуть с коментариями подробными или подсказать с чего начать?

Реализация алгоритма, составить код по схеме
подскажите пожалуйста как в C# реализовать данный алгоритм

Код для RC4
Добрый день! Нужен код RC4. Искал, находил, но неработает( Скиньте рабочий пожалуйста. Заранее спасибо и всех благ

2
0 / 0 / 1
Регистрация: 28.02.2013
Сообщений: 26
23.05.2014, 16:28
Более-менее понятно тут http://habrahabr.ru/post/111510/
0
2 / 2 / 1
Регистрация: 04.12.2012
Сообщений: 202
23.05.2014, 16:38  [ТС]
оттуда код и взят. там ничего про это не написано
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
23.05.2014, 16:38
Помогаю со студенческими работами здесь

Архиватор на основе алгоритма Хаффмана, помогите разобрать код.
Всем привет :) вот в чем собственно вопрос или просьба... мне задана курсовая работа &quot;Архиватор на основе алгоритма Хаффама&quot;. ...

Качественная реализация RC4 на javascript
1. подскажите ссылочку на качественную реализацию RC4 на javascript ? требование - чтобы работала достаточно быстро для того, чтобы ...

Как разобрать ключи алгоритма RSA/ECB/PKCS1Padding?
Есть вот это: RSAPrivateKey:...

Разобрать код и создать приложение использующее этот код
ПОМОГИТЕ ПОЖАЛУЙСТА Option Explicit Private Sub Form_DragDrop(Source As Control, x As Single, y As Single) If TypeOf Sourse Is...

Реализация алгоритма
Всем привет! Подскажите плиз,как можно реализовать алгоритм. Есть поле,которое может принемать любой размер,к примеру такое ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
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