Реализация HMAC-SHA256 в openssl - PullRequest
0 голосов
/ 28 января 2019

Я использовал библиотеку openssl для реализации HMAC-SHA256 с использованием HMAC_CTX.Фактический результат отличается от ожидаемого.Я пробовал этот код

int hmac_sha256(char *key, const unsigned char *string, int mlen, char 
outputBuffer[65])
{
unsigned int len = 0;
//unsigned char hash[EVP_MAX_MD_SIZE];
unsigned char hash[65];

unsigned char *ptr = NULL;
HMAC_CTX ctx;
HMAC_CTX_init(&ctx);
HMAC_Init_ex(&ctx, key, strlen(key), EVP_sha256(), NULL);
HMAC_Update(&ctx, string, mlen);
HMAC_Final(&ctx, hash, &len);
 for (int i = 0; i < 65; i++)
{
    sprintf(outputBuffer + (i * 2), "%02x", hash[i]);
}
HMAC_CTX_cleanup(&ctx);
return 1;}

В основном коде:

подпись символа [65];

retVal = hmac_sha256 (ключ, (const unsigned char *) tempMessage, strlen (tempMessage), подпись);

Я пробовал другой

int hmac(unsigned char *key, unsigned int key_len, unsigned char *data, 
unsigned int data_len, char outputBuffer[64], unsigned int *out_len)

{

#define BLOCK_SIZE 64

unsigned int i, nkey, o_len;
char i_pad[BLOCK_SIZE], o_pad[BLOCK_SIZE];

/* Key init */

if (key_len > BLOCK_SIZE)
    key = hash(key, key_len, &nkey);
else if (key_len < BLOCK_SIZE) 
{
    // zero pad to the right
    char *n_key =(char *) malloc(BLOCK_SIZE);
    memset(n_key, '\0', BLOCK_SIZE);
    memcpy(n_key, key, key_len);
    key =(unsigned char *)n_key;
}

for (i = 0; i<BLOCK_SIZE; i++) 
{
    o_pad[i] = key[i] ^ 0x5c;
    i_pad[i] = key[i] ^ 0x36;
}

unsigned char *stg1 =(unsigned char*) malloc(BLOCK_SIZE + data_len);
memcpy(stg1, i_pad, BLOCK_SIZE);
memcpy(stg1 + BLOCK_SIZE, data, data_len);


stg1 = hash(stg1, BLOCK_SIZE + data_len, &o_len);

unsigned char *stg2 =(unsigned char*) malloc(BLOCK_SIZE + o_len);
memcpy(stg2, o_pad, BLOCK_SIZE);
memcpy(stg2 + BLOCK_SIZE, stg1, o_len);


stg2 = hash(stg2, BLOCK_SIZE * 2 + data_len, &o_len);

/*EVP_MD_CTX ctx;
EVP_MD_CTX_init(&ctx);
EVP_DigestInit_ex(&ctx, EVP_sha256(), NULL);
EVP_DigestUpdate(&ctx, o_pad, BLOCK_SIZE);
EVP_DigestUpdate(&ctx, stg1, o_len);
EVP_DigestFinal_ex(&ctx, stg2, &o_len);
 EVP_MD_CTX_cleanup(&ctx);*/

for (int i = 0; i < 32; i++)
{
 sprintf(outputBuffer + (i * 2), "%02x", stg2[i]);
}

  return 1;
 }

Фактический результат отличается от ожидаемого результата.Я не могу привести примеры, поскольку они представляют собой данные XML длиной 5000 байт.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...