Форум программистов, компьютерный форум, киберфорум
Python: Научные вычисления
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/64: Рейтинг темы: голосов - 64, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 28.11.2017
Сообщений: 3

Алгоритм ГОСТ Р 34.12-2015 «МАГМА»

21.12.2017, 01:17. Показов 12926. Ответов 1

Студворк — интернет-сервис помощи студентам
Доброго времени суток! Столкнулся со следующей проблемой. Реализовал вышеописанный алгоритм, однако он не работает в режиме расшифровки. Преподаватель сказал, что в связи с использованием сети Фейстеля, скорее всего ошибка где-то на этапах взятия ключа или обмена старших битов с младшими. Но я уже все перепробовал -- ничего.

Программа состоит из двух файлов: start.py и tools.py. Последний содержит в себе некоторые инструменты, такие как, считывание 64-битных блоков, считывание ключа и прочие процедуры конвертации. Файл start.py организует именно шифрование.

start.py:

Python
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
#!/usr/bin/python2.7
from bitarray import bitarray
from tools import *
import sys
 
def main(msg, key, mode = False):
    bits = read(msg, 64); outbits = bitarray()
    keys = read(key, 32)
    for subbits in bits: outbits.extend(coding(subbits, keys, mode))
    writeBits(outbits)
 
def coding (bits, keys, mode):
    leftBits, rightBits = bits[:32], bits[32:]
    if mode == False:
        for i in range(3):
            for j in range(8):
                rightBits = rightBits ^ keys[j]
                rightBits = replaceS(rightBits)
                rightBits = cycleShift11(rightBits)
                result = leftBits ^ rightBits
                rightBits = leftBits
                leftBits = result
        for j in range(7, -1, -1):
            rightBits = rightBits ^ keys[j]
            rightBits = replaceS(rightBits)
            rightBits = cycleShift11(rightBits)
            result = leftBits ^ rightBits
            if (j != 0):
                rightBits = leftBits
                leftBits = result
            if (j == 0):  rightBits = result
 
    if mode == True:
        for j in range(7, -1, -1):
            rightBits = rightBits ^ keys[j]
            rightBits = replaceS(rightBits)
            rightBits = cycleShift11(rightBits)
            result = leftBits ^ rightBits
            rightBits = leftBits
            leftBits = result
        for i in range(3):
            for j in range(8):
                rightBits = rightBits ^ keys[j]
                rightBits = replaceS(rightBits)
                rightBits = cycleShift11(rightBits)
                result = leftBits ^ rightBits
                if ((i + 2) * (j + 1)) != 32:
                    rightBits = leftBits
                    leftBits = result
                if ((i + 2) * (j + 1)) == 32:
                    rightBits = result
    leftBits.extend(rightBits)
    return leftBits
msg = sys.argv[1]
if sys.argv[2] == '0': mode = False
else: mode = True
main(msg, "key", mode)
tools.py

Python
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
from bitarray import bitarray
from math import pow
SBlocks = [[12, 4, 6, 2, 10, 5, 11, 9, 14, 8, 13, 7, 0, 3, 15, 1],
       [6, 8, 2, 3, 9, 10, 5, 12, 1, 14, 4, 7, 11, 13, 0, 15],
       [11, 3, 5, 8, 2, 15, 10, 13, 14, 1, 7, 4, 12, 9, 6, 0],
           [12, 8, 2, 1, 13, 4, 15, 6, 7, 0, 10, 5, 3, 14, 9, 11],
           [7, 15, 5, 10, 8, 1, 6, 13, 0, 9, 3, 14, 11, 4, 2, 12],
       [5, 13, 15, 6, 9, 2, 12, 10, 11, 7, 8, 1, 4, 3, 14, 0],
       [8, 14, 2, 5, 6, 9, 1, 12, 15, 4, 11, 0, 13, 10, 3, 7],
       [1, 7, 14, 13, 0, 5, 8, 3, 4, 15, 10, 6, 9, 12, 11, 2]]
def writeBits(bits):
    bytes = bits.tobytes()
    f = open("newfile", "w")
    f.seek(0); f.write(bytes)
def cycleShift11(bits):
    l = bits[: 11]; r = bits[11: ]
    result = bitarray()
    result.extend(r); result.extend(l)
    return result
def toQuart(bits):
        '''процедура, которая приводит некоторые значения 4-битовых фрагментов в надлежащий вид. Например 0b1 -> 0b0001'''
    pattern = '0000'[len(bits): ]
    result = bitarray(pattern)
    result.extend(bits)
    return result
def replaceS(bits):
    indexes = []
    for i in range(0, len(bits) + 4, 4):
        if i != 0: indexes.append(bit2int(bits[abs(4 - i): i]))
    result, s = bitarray(), bitarray(); k = 0
    for indx in indexes: 
        value = SBlocks[k][indx]
        s = int2bit(value)
        if len(s) < 4: s = toQuart(s)
        result.extend(s)
        k += 1
    return result
def read(path, n):
    '''read for n bits from file'''
    f = open(path); filebits = bitarray(); filebits.fromfile(f)
    bits = []; begin, end = 0, 0
    if len(filebits) == n: bits = [filebits]
    if (len(filebits) % n == 0) and (len(filebits) > n):
        for i in range(0, len(filebits), n):
            begin = i; end = i + n
            bits.append(filebits[begin: end])
    return bits
def int2bit(n):
    sbits = bin(n)[2:]; bits = bitarray()
    for bit in sbits:
        if bit == '1': bits.append(True)
        else: bits.append(False)
    return bits 
def bit2int(bits): return int(bits.to01(), 2)
message содержит:

hello!!\n

newfile после шифрования будет содержать закрытый текст
-®„}k°5,Œ_Ÿà ;o`
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
21.12.2017, 01:17
Ответы с готовыми решениями:

OpenSSL + гост 2015 (кузнечик)
Добрый день! Необходимо настроить для postgresql - openssl с поддержкой гост 2015(кузнечик). В интернете нашёл только гост 2012. ...

ГОСТ 34.12-2015 и его неприводимый полином
Добрый день! у меня вопрос, в ГОСТ 34.12-2015 используется неприводимый полином GF({2}^{8}) f(x) = {x}^{8} + {x}^{7} + {x}^{6} + x + 1 ...

Написать код на тему: "Базовый алгоритм шифрования Магма". С использованием цикла
Добрый день! Помогите написать код на матлабе на тему:Базовый алгоритм шифрования Магма. С использованием цикла. Информация, подлежащая...

1
0 / 0 / 0
Регистрация: 28.11.2017
Сообщений: 3
21.12.2017, 01:24  [ТС]
Ну, и более нагляднее работа программы. Значение 0 -- режим зашифровывания, 1 -- режим дешифрирования
Миниатюры
Алгоритм ГОСТ Р 34.12-2015  «МАГМА»  
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
21.12.2017, 01:24
Помогаю со студенческими работами здесь

Не работает шифрование по ГОСТ 28147-89, ГОСТ Р 34.10-2001,ГОСТ Р 34.11-94 (ASP.NET)
Создавал веб-приложение(ASP.Net) для шифрования по данным гостам, нашёл по данной теме код, но он не рабочий(VS ошибок не выдаёт, но при...

Реализация ГОСТ Р 34.12-2015"Кузнечик"
Друзья, помогите мне понять как реализовать алгоритм шифрования Кузнечик. Я прочитал ГОСТ, но ясности в голове нету, поэтому и не могу...

Объясните алгоритм хэширования: ГОСТ Р 34.11-94
Доброго времени суток) Объясните, пожалуйста, алгоритм хэширования госта р 34.11-94) И очень приятным дополнением была бы готовая...

алгоритм шифрования ГОСТ 28147-89
писалось на коленке за 1 день. режим простой замены.для имитовставки воспользоваться 2 раундами. здесь же,подсчет CRC32 взят у...

Алгоритм шифрования ГОСТ 28147-89
Всем привет, реализую алгоритм данный алгоритм шифрования, хотелось бы прояснить пару моментов. Не совсем понимаю, как считывать файлы:...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
SDL3 для Web (WebAssembly): Работа со звуком через SDL3_mixer
8Observer8 08.02.2026
Содержание блога Пошагово создадим проект для загрузки звукового файла и воспроизведения звука с помощью библиотеки SDL3_mixer. Звук будет воспроизводиться по клику мышки по холсту на Desktop и по. . .
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru