12 / 12 / 4
Регистрация: 17.11.2010
Сообщений: 143
1

CryptoAPI

19.05.2013, 11:38. Показов 3339. Ответов 1
Метки нет (Все метки)

Подскажите, пожалуйта, как получить хэш строки (алгоритм хеширования неважен)
Есть такие функции:
C++
1
2
3
4
5
CryptCreateHash
CryptDestroyHash
CryptDuplicateHash
CryptGetHashParam 
CryptHashData
Но как из этого всего хэш извлечь ?
0

Помощь в написании контрольных, курсовых и дипломных работ здесь.

Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
19.05.2013, 11:38
Ответы с готовыми решениями:

CryptoApi
Как зашифровать и дешифровать текст с помощью cryptoapi, пример если можно

CryptoAPI языка Си (C++)
Здравствуйте! Возник вопрос, который я не могу найти/не знаю как правильно искать в интернетах. ...

Cryptoapi in C#
Может быть, кто-нибудь знает, какие-нибудь крипто-библиотеки (DLL) сторонних разработчиков,...

AES на CryptoAPI
Вот написал программку , для шифрования по AES. При режиме "шифрование" ничего не меняется. ...

1
Эксперт С++
2354 / 1643 / 274
Регистрация: 29.05.2011
Сообщений: 3,373
19.05.2013, 15:05 2
Лучший ответ Сообщение было отмечено как решение

Решение

В документации вроде довольно понятно всё, с примерами.
CryptAcquireContext() - получаем контекст криптопровайдера
CryptCreateHash() - создаём объект алгоритма хеширования
CryptHashData() - суём данные (сразу все или поблочно)
CryptGetHashParam() - получаем результат
CryptDestroyHash() - удаляем хэш
CryptReleaseContext() - освобождаем контекст

Вот, переделано из примеров в MSDN:
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
#include <iostream>
#include <vector>
#include <windows.h>
#include <wincrypt.h>
 
int main()
{
    HCRYPTPROV hCryptProv;
    HCRYPTHASH hHash;
 
    //--------------------------------------------------------------------
    // Get a handle to a cryptography provider context.
 
 
    if(CryptAcquireContext(
                &hCryptProv, 
                NULL, 
                NULL, 
                PROV_RSA_FULL, 
                CRYPT_VERIFYCONTEXT)) 
    {
        printf("CryptAcquireContext complete. \n");
    }
    else
    {
        printf("Acquisition of context failed.\n");
        exit(1);
    }
    //--------------------------------------------------------------------
    // Acquire a hash object handle.
 
    if(CryptCreateHash(
                hCryptProv, 
                CALG_MD5, 
                0, 
                0, 
                &hHash)) 
    {
        printf("An empty hash object has been created. \n");
    }
    else
    {
        printf("Error during CryptBeginHash!\n");
        exit(1);
    }
 
    char data1[] = "First part.";
    char data2[] = " Second part.";
 
    if (
            !CryptHashData(hHash, (BYTE*)data1, sizeof(data1) - 1, 0) ||
            !CryptHashData(hHash, (BYTE*)data2, sizeof(data2) - 1, 0))
    {
        printf("Error during CryptHashData!\n");
        exit(1);
    }
    DWORD dwHashLen, dwHashLenSize = sizeof(DWORD);
    if(!CryptGetHashParam(
       hHash,
       HP_HASHSIZE,
       (BYTE *)&dwHashLen,
       &dwHashLenSize,
       0))
    {
        printf("CryptGetHashParam failed to get size.");
        exit(1);
    }
 
    std::vector<BYTE> bHash(dwHashLenSize);
 
    if(CryptGetHashParam(
                hHash,
                HP_HASHVAL,
                &bHash[0],
                &dwHashLen,
                0))
    {
        // Print the hash value.
        printf("The hash is:  ");
        for(DWORD i = 0 ; i < dwHashLen ; i++)
        {
            printf("%02x ",bHash[i]);
        }
        printf("\n");
    }
    else
    {
        printf("Error during reading hash value.");
        exit(1);
    }
 
    //--------------------------------------------------------------------
    // After processing, hCryptProv and hHash must be released.
 
    if(hHash) 
        CryptDestroyHash(hHash);
    if(hCryptProv) 
        CryptReleaseContext(hCryptProv,0);
 
    return 0;
}
Код
$ echo -n "First part. Second part." | md5sum
89c2f90b5cc62e9aecce714e7e240c6b  -
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
19.05.2013, 15:05

Помощь в написании контрольных, курсовых и дипломных работ здесь.

CryptoAPI & C++
Добрый день. Вот возникла такая задачка: есть ключ, в BLOB формате(т.е. набор байтов, алгоритм...

RC5 CryptoAPI
Знатоки CryptoAPI, подскажите, пожалуйста, для RC5 какой длины нужен ключ? В википедии был,...

cryptoapi, SHA-1
char *str = new char; //данные HCRYPTPROV hCryptProv = 0; HCRYPTHASH hHash = 0; gets(str);...

CryptoAPI | РСА шифрование
Приветствую всех. Пытаюсь шифровать текст при помощи RSA. Имеются следующие вопросы : 1. Дабы...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.