Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
2 / 2 / 0
Регистрация: 04.03.2013
Сообщений: 46

Гаммирование

25.10.2013, 14:24. Показов 7718. Ответов 0
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Разработать программу на С++ для реализации алгоритма шифрования и расшифрования данных, используя метод гаммирования и поразрядного циклического сдвига. Алгоритм: для блока данных заданного размера берется такого же размера фрагмент гаммы и выполняется операция поразрядного исключающего «ИЛИ», далее, выполняется операция поразрядного циклического сдвига на заданное число бит влево или вправо с полученным новым блоком. Расшифрование выполняется в обратном порядке, вначале циклический сдвиг в противоположную сторону, а затем операция поразрядного исключающего «ИЛИ» с блоками той же самой гаммы.
Для получения гаммы можно использовать стандартный генератор псевдослучайный чисел (функцию rand, функция rand() генерирует воспроизводимую последовательность псевдослучайных чисел, при каждом обращении к функции возвращается целое в интервале между нулем и значением RAND_MAX, которое в любой реализации должно быть не меньше числа 32767, обратить внимание, при величине обрабатываемого блока данных 4 байта, возможно, для заполнения блока гаммы использовать два вызова функции), для начальной инициализации генератора использовать функцию srand (значение начальной инициализации является частью секретного ключа, другой частью ключа является размер поразрядного сдвига и его направление). Шифруемые данные хранить в программе в виде строки (можно сохранять в файле и читать из файла).

Мой вариант: сдвиг на 2 бита, размер обрабатываемого блока 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
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
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
#include <iostream>
#include "stdafx.h"
#include <locale.h>
#include <string.h>
#include<conio.h>
#include<stdio.h>
#include <stdlib.h>
 
const int MAX=1000; // MAX - Максимальное количество символов
// PrintLine - Функция печати строки длиной в 'b' символов
void PrintLine(char *line, int b)
{
    for (int i=0; i<b; i++)
        printf("%c", line[i]);
    printf("\n");
}
//Функция для шифрования данных
void shifrovanie(char *first, char *late,  int y, int n)
{
    srand(n);   // Инициализация секретного ключа 'n'
    unsigned short Gamma;   // Гамма
    int SizeLateBlock;  // Размер последнего блока
    unsigned short Block1, Block2;  // Блоки, которые будут использованы в качестве буфера обмена
    int x;  // x - Количество блоков памяти
    
    x=y/1; //  Количество блоков памяти по 1 байт
    
    if (x*1!=y)     // Проверка количества блоков по 1 байт
    {
        SizeLateBlock=1;    // Если есть лишний блок, то его размер - 1 байт
        x++;    // Увеличиваем кол-во итераций цикла (для обработки последнего блока размером 1 байт)
    }
    else SizeLateBlock=1;
    
    for (int i=1; i<=x; i++)
    {
        Gamma=rand();   // Генерируем гамму с помощью генератора псевдослучайных чисел
        unsigned short Mask=0x8000;  // Маска для сохранения одного старшего бита
        
        if (i!=x)   // Проверка, является ли обрабатываемый блок последним
        {
            memcpy(&Block1, first+(i-1), 1);    //  Копирование блока исходных данных размером 1 байт из исходной строки в буферный блок данных
            Block2=Block1^Gamma; // Наложение гаммы на буферный блок данных, используя операцию поразрядного исключающего "ИЛИ"
            Block1=Block2 & Mask; // Наложение маски, чтобы выделить отдельные биты и сохранить их в отдельном буферном блоке
            Block1>>=14; // Выполнениеоперации поразрядного сдвига на 14 бит вправо
            Block2<<=2; // Выполнение операции поразрядного сдвига на 2 бита влево
            Block2|=Block1; // Использование операции поразрядного "ИЛИ", получение поразрядно сдвинутого на 2 бита влево исходного блока с наложенной гаммой
            memcpy(late+(i-1), &Block2, 1); // Копирование результата из буфера в блок с зашифрованными данными
        }
        else  // Если блок последний
        {
            if (SizeLateBlock==1)
                Mask>>=4;   // Сдвиг маски, если размер последнего блока данных - 1 байт
            Block1=0; // Далее те же операции, но с учетом того, что идет обработка одного или двух байтов
            memcpy(&Block1, first+(i-1), SizeLateBlock);
            Block2=Block1^Gamma;
            Block1=Block2 & Mask;
            Block1>>=(14-4*(1-SizeLateBlock)); // Учитывание размера последнего блока
            Block2<<=2;
            Block2 = Block1;
            memcpy(late+(i-1), &Block2, SizeLateBlock);
        }
        
    }
}
//Функция для расшифровывания данных
 using namespace std;
void deshifrovanie(char *late, char *first, int y, int n)
{
    srand(n); // Инициализация секретного ключа
    unsigned short Gamma;   // Гамма
    int x; // x - Количество блоков памяти
    int SizeLateBlock; // Размер последнего блока
    unsigned short Block1, Block2;  // Блоки, которые будут использованы в качестве буфера обмена
    
    x=y/1; //  Количество блоков памяти по 1 байт
    
    if (x*1!=y) // Проверка количества блоков по 1 байт
    {
        SizeLateBlock=1; // Если есть лишний блок, то его размер - 1 байт
        x++; // Увеличивание кол-ва итераций цикла(для обработки последнего блока размером 1 байт)
    }
    else SizeLateBlock=1;
    
    for (int i=1; i<=x; i++)
    {
        Gamma=rand(); // Генерация гаммы с помощью генератора псевдослучайных чисел
        unsigned short Mask=0x0001; // Маска для сохранения двух младших битов
        if (i!=x) // Проверка, является ли обрабатываемый блок последним
        {
            memcpy(&Block1, late+(i-1), 1); // Копирование блока зашифрованных данных размером 1 байт из исходной строки в буферный блок данных
            Block2=Block1 & Mask; // Наложение маски, чтобы выделить отдельные биты и сохранить их в отдельном буферном блоке
            Block2<<=14; // Выполнение операции поразрядного сдвига на 14 бит влево
            Block1>>=2; // Выполнение операции поразрядного сдвига на 2 бита вправо
            Block1|=Block2; // Использование операции поразрядного "ИЛИ", получение поразрядно сдвинутого на 1 бит вправо исходного блока зашифрованных данных
            Block2=Block1^Gamma; // Наложение гаммы, используя операцию поразрядного исключающего "ИЛИ", и получаем блок исходных данных
            memcpy(first+(i-1), &Block2, 1); // Копирование результата из буфера в блок с расшифрованными данными
        }
        else
        {
            Block1=0; // Далее те же операции, что и при выполнении условия, с учетом того, что идет обработка одного или двух байтов
            memcpy(&Block1, late+(i-1), SizeLateBlock);
            Block2=Block1 & Mask;
            Block2<<=(14-4*(1-SizeLateBlock)); // Учитываем размер последнего блока
            Block1>>=2;
            Block1|=Block2;
            Block2=Block1^Gamma;
            memcpy(first+(i-1), &Block2, SizeLateBlock);
        }
        
    }
}
//Главная функция 
int main()
{
    setlocale(LC_ALL, "rus");
    int  Key;   // Key - Секретный ключ
    char Original[MAX], Encrypt[MAX], Decrypt[MAX]; // Original - Исходные, Encrypt - Зашифрованные, Decrypt - Расшифрованные
    int a;
    printf("Введите данные, которые вы хотите зашифровать: ");
    gets(Original); // Ввод исходных данных
    a=strlen(Original); // Длина строки
    printf("Введите ключ: ");
    scanf("%d", &Key); // Ввод секретного ключа
    shifrovanie(Original, Encrypt, a, Key); // Шифрование исходных данных
    printf("\nЗашифрованные данные: ");
    PrintLine(Encrypt, a); // Вывод зашифрованных данных на экран
    printf("\nВведите ключ: ");
    scanf("%d", &Key); // Ввод секретного ключа
    srand(Key);
    deshifrovanie(Encrypt, Decrypt, a, Key); // Расшифровывание зашифрованных данных
    printf("\nРасшифрованные данные: ");
    PrintLine(Decrypt,a);   //Вывод расшифрованных данных
    getch();
    return 0;
}
Заранее спасибо!
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.10.2013, 14:24
Ответы с готовыми решениями:

Гаммирование с обратной связью
Нужна помощь ребят. Я не програмист и С++ учил только самые основы, но в универе по предмету криптологии напрягли с прогой... Нужна хоть...

ГОСТ 28147 Гаммирование
Нашел вот на форуме код.. мне по заданию нужно разделить входящий текст на блоки в 64 бита, зашифровать и потом вывести первые два...

Гаммирование
Здравствуйте! Ребята, подкиньте, если у кого есть, алгоритм шифрования методом гаммирования. Нужен исходный код. Желательно на...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.10.2013, 14:24
Помогаю со студенческими работами здесь

Гаммирование
Пожалуйста прошу помочь Вас! Дело в том, что впервые столкнулся с гаммированием и необходимо было его реализовать. C++ подошёл бы лучше, но...

Гаммирование
Гаммирование Процесс зашифрования заключается в генерации гаммы шифра и наложении этой гаммы на исходный открытый текст. Перед...

Гаммирование
Вот начала писать, но не могу понять чего не хватает, посмотрите пожалуста... нужно ввести сообщение і гамму патом зашифровать і...

Гаммирование на Java
Нужно написать для курсовика программу шифрования методом гаммирования,на java в eclipse.короче пишешь текст,он сохраняется в файл в виде...

гаммирование, перемешивание и рассеивание
Кто знает как можно это сделать https://www.cyberforum.ru/order-work-software/thread1395117.html


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений. 9TO2GP2bpX4 a42b81fb172ffc12ca589c7898261ccb/ https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/ Слева синяя линия -. . .
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. . Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru