Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611

Использование классов (sha1)

27.12.2015, 19:20. Показов 2851. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В sha1.h
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
/* sha1.h */
#ifndef SHA1_H
#define SHA1_H
#include <stdint.h>
 
#ifdef __cplusplus
extern "C" {
#endif
 
#define sha1_block_size 64
#define sha1_hash_size  20
 
/* algorithm context */
typedef struct sha1_ctx
{
  unsigned char message[sha1_block_size]; /* 512-bit buffer for leftovers */
  uint64_t length;   /* number of processed bytes */
  unsigned hash[5];  /* 160-bit algorithm internal hashing state */
} sha1_ctx;
 
/* hash functions */
 
void sha1_init(sha1_ctx *ctx);
void sha1_update(sha1_ctx *ctx, const unsigned char* msg, unsigned size);
void sha1_final(sha1_ctx *ctx, unsigned char* result);
 
#ifdef __cplusplus
} /* extern "C" */
#endif /* __cplusplus */
 
#endif /* SHA1_H */
Вот сляпал функцию, чтобы код не писать 3 раза...:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
void KeyHashSha1(byte result[5], const byte * msg, unsigned size)
{
    sha1_ctx ctx; sha1_init(&ctx); // Инициализация
 
    byte buffer[sha1_block_size];
    unsigned i = -1;
 
    while(i < size)
    {
        strncpy_s((char)&buffer, (const char*)msg[i], (size_t)(sha1_block_size / 8)); // Читать по 8 байт
        sha1_update(&ctx, buffer, size); // Запихивать в sha1
        i += sha1_block_size / 8; // Шаг 8 байт
    }
    sha1_final(&ctx, result); // Результат
}
А так пытаюсь получить:
C++
1
2
3
4
5
wchar_t wPass[128]; GetWindowTextW(hEdit[1], wPass, eLen[1] + 1); // Получить текст из формы в двухбайтовую строку
 
byte bPass[256]; std::copy(wPass, wPass + eLen[0], reinterpret_cast<wchar_t>(bPass)); // Конвертировать в 1байтовую строку
 
byte iSha1[5]; KeyHashSha1(iSha1, bPass, strlen(bPass)); // Получить хэш из пароля
Вот тут вообще не пойму, всё красным подчёркнуто:
C++
1
strncpy_s((char)&buffer, (const char*)msg[i], (size_t)(sha1_block_size / 8)); // Читать по 8 байт
И в целом, я вообще в ту сторону иду?
Или там цикл вообще не нужен?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.12.2015, 19:20
Ответы с готовыми решениями:

Множественное наследование, Перегрузка функций, Перегрузка операторов, Использование дружественных функций и классов, Использование шаблонов классов
Здравствуйте!!! Я бы хотел попросить помоч решить...ну или скинуть примеры таких задач, если вдруг у вас они завалялись на компе или...

Проверка файла на MD5 и SHA1 и сравнение с готовым MD5 и SHA1
Есть файл text.txt на него md5:53734131cd0cf82dfbbe85e0459089e9 и sha1:8f38ce7cb44c0b78f9cb4de6ddedba2107525386 Код: @echo off ...

Использование классов
Здравствуйте, скажите зачем вообще использовать классы, лишь для &quot;удобства&quot;? или есть реальные случаи когда без них не обойтись? И...

9
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
27.12.2015, 19:38
Лучший ответ Сообщение было отмечено артист как решение

Решение

Тебе вообще не нужен этот массив, передавай указатель сразу:
C++
1
2
3
wchar_t wPass[128]; GetWindowTextW(hEdit[1], wPass, eLen[1] + 1); // Получить текст из формы в двухбайтовую строку
 
byte iSha1[5]; KeyHashSha1(iSha1, reinterpret_cast<const byte *>(wPass), wcslen(wPass) * 2); // Получить хэш из пароля
KeyHashSha1() не правильная. Почему там -1, а не 0? Почему по 8 байт, а не по 64? Размер блока 64 байта же у sha1. Почему результат 5 байт? sha1 - 20 байт.
И strncpy() здесь не подходит, надо копировать просто блоки std::copy().
Не понятно назначение size у той функций. Что означает этот параметр? Может она весь буфер разом обработать может без цикла?
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
27.12.2015, 19:51  [ТС]
Цитата Сообщение от nmcf Посмотреть сообщение
KeyHashSha1() не правильная.
Я подозревал )

Цитата Сообщение от nmcf Посмотреть сообщение
Почему там -1, а не 0?
Я просто сначала по привычке while(++i... написал, забыл исправить ))

Цитата Сообщение от nmcf Посмотреть сообщение
Почему по 8 байт, а не по 64? Размер блока 64 байта же у sha1.
Я думал это в битах...

Цитата Сообщение от nmcf Посмотреть сообщение
Почему результат 5 байт? sha1 - 20 байт.
Осталось от винраровского кода, там было unsignet не то лонг не то инт, в общем 4х байтовая, 4 * 5 = 20.

Спасибо.
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
27.12.2015, 19:52
Лучший ответ Сообщение было отмечено артист как решение

Решение

Так что на счёт size у sha1_update()? Достаточно 1 раз вызвать с размером всего входного блока?
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
27.12.2015, 20:47  [ТС]
А, т.е. не так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
void KeyHashSha1(byte * result, const byte * msg, int size)
{
    sha1_ctx ctx; sha1_init(&ctx); // Инициализация
 
    byte buffer[sha1_block_size];
    int i = 0;
 
    while(i < size)
    {
        strncpy_s((char)buffer, (const char*)msg[i], (size_t)sha1_block_size); // Читать по 64 байт
        sha1_update(&ctx, buffer, sha1_block_size); // Запихивать в sha1
        i += sha1_block_size; // Шаг 64 байт
    }
    sha1_final(&ctx, result); // Результат
}
А так?
C++
1
2
3
4
5
6
7
8
void KeyHashSha1(byte * result, const byte * msg, int size)
{
    sha1_ctx ctx; sha1_init(&ctx); // Инициализация
 
    sha1_update(&ctx, msg, size); // Запихивать в sha1
    
    sha1_final(&ctx, result); // Результат
}
Я скомпилировать не могу уже 3й день
Так, что проверить не могу )
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
27.12.2015, 22:29
Возможно. Это же твои функции. Должен знать, для чего size.
0
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
27.12.2015, 22:54  [ТС]
Не знаю, в sha1_update нужно длину отправить...

Не работает...
Название: 1.jpg
Просмотров: 71

Размер: 18.6 Кб
Название: 2.jpg
Просмотров: 71

Размер: 11.2 Кб

C++
1
2
3
4
5
6
7
8
9
10
11
wchar_t wPass[128]; GetWindowTextW(hEdit[1], wPass, eLen[1] + 1); // Получить текст из формы в двухбайтовую строку
 
//std::copy(wPass, wPass + eLen[0], reinterpret_cast<wchar_t *>(bPass)); // Конвертировать в 1байтовую строку
size_t i; wcstombs_s(&i, (char *)bPass, (size_t)256, (const wchar_t *)wPass, (size_t)256);
 
byte iSha1[20]; KeyHashSha1(iSha1, bPass, strlen((const char *)bPass)); // Получить хэш из пароля
 
MessageBoxA(hWnd, (LPCSTR)iSha1, "BYTE", 0);
 
char Hex[40]; ByteToHex(Hex, iSha1);
MessageBoxA(hWnd, Hex, "abc", 0);
C++
1
2
3
4
5
6
7
8
void KeyHashSha1(byte * result, const byte * msg, int size)
{
    sha1_ctx ctx; sha1_init(&ctx); // Инициализация
 
    sha1_update(&ctx, msg, size); // Запихивать в sha1
    
    sha1_final(&ctx, result); // Результат
}
C++
1
2
3
4
5
6
7
8
9
10
void ByteToHex(char Hex[], byte Sourse[])
{
    char const hex_chars[16] = {'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};
 
    for(int j = 0, i = 0; i < strlen((char *)Sourse); ++i)
    {
        Hex[j++] += hex_chars[(Sourse[i] & 0xF0) >> 4];
        Hex[j++] += hex_chars[(Sourse[i] & 0x0F) >> 0];
    }
}
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
27.12.2015, 23:42
Лучший ответ Сообщение было отмечено артист как решение

Решение

Вот, без этого массива. Не нужен он.
C++
1
2
3
4
5
6
7
8
9
10
wchar_t wPass[128];
GetWindowTextW(hEdit[1], wPass, 128); // Получить текст из формы в двухбайтовую строку
 
byte iSha1[20];
KeyHashSha1(iSha1, reinterpret_cast<const byte *>(wPass), wcslen(wPass) * sizeof(wchar_t)); // Получить хэш из пароля
 
std::wostringstream oss;
for (int i = 0; i < 20; ++i) oss << std::hex << std::setw(2) << std::setfill('0') << static_cast<unsigned>(iSha1[i]);
 
MessageBoxW(hWnd, oss.str().c_str(), "BYTE", 0);
1
 Аватар для артист
50 / 35 / 21
Регистрация: 17.09.2014
Сообщений: 1,611
28.12.2015, 21:08  [ТС]
Не правильно он шифрует...
На 2х онлайн сервисах:
事奉聖禮釋義
8e3992de200bd067a36687634144598fe860a455
А у меня вывело:
98f5b20828c831def4ab2eef40fb9370d3a4437c cccccccccccccccc8b4e49595680ae79cb91a97f 80

И программа завершилась крахом

Есть у кого нормальные sha1 .cpp и .h ?
0
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
28.12.2015, 21:55
Что-то неправильно делаешь.
Windows умеет рассчитывать sha1: cryptoapi, SHA-1
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.12.2015, 21:55
Помогаю со студенческими работами здесь

Использование классов
Подскажите как использовать класс на премере. Пожалуйста. Вообщем есть код: 1. Авторизация, скрипт обработки, и скрипт показа инфы(вход...

Использование классов
Класс Члены класса Методы Операторы перегрузки Исходные данные Матрица Размерность ...

Использование классов
Расскажите пожалуйста на кокретных примерах как и где модно использовать классы?

Использование классов
Здравствуйте господа программисты. Помогите мне пожалуста. В Курсовой есть такое задание: &quot;Создать телефонную книгу&quot; ...

Использование классов
Не хочет запускаться, помогите найти ошибку #include &lt;iostream&gt; #define N 5 using namespace std; class electronic_store { ...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru