Openssl EVP API не может расшифровать зашифрованный текст, когда он читается из файла (AES 128 ecb) - PullRequest
1 голос
/ 19 марта 2019

Я пытаюсь создать простое приложение, которое шифрует и дешифрует небольшой файл, <10 байт. Я использую OpenSSL API C (шифрование AES-128 ecb), и я сталкиваюсь со странной «ошибкой», когда я шифрую строку и сохраняю ее в файл. </p>

unsigned char buffer[256];
unsigned char rcv[256];
char my_string[]={"123456"};

int bil = aes_encrypt(my_string, strlen(my_string), "1", NULL, buffer);

FILE* fp =fopen("encrypted_file","w");
write(fileno(fp),buffer,bil);
fclose(fp);

aes_decrypt(buffer, bil, "1", NULL, rec);

printf("%s\n",rec); /* Correct: Prints 123456 */

Проблема здесь в том, что если я прочитал зашифрованный текст из файла, хотя это именно тот файл, который я ранее сохранил, он, похоже, не будет правильно расшифрован.

FILE* fp =fopen("encrypted_file","r");

int bil = read(fileno(fp),buffer,256); /* The buffer contains the exact cipher that was created by the aes_encrypt in the first place */
fclose(fp);

int y = aes_decrypt(buffer, bil, "1", NULL, rec);

printf("%s\n",rec);  /* Emptry string */

Функции шифрования и дешифрования показаны ниже:

Шифрование

int
aes_encrypt(unsigned char *plaintext, int plaintext_len, unsigned   char *key,
unsigned char *iv, unsigned char *ciphertext){
    EVP_CIPHER_CTX* ctx;

    int len;
    int ciphertext_len;

    ctx = EVP_CIPHER_CTX_new();
    EVP_EncryptInit_ex(ctx, EVP_aes_128_ecb(), NULL, key, iv);
    EVP_EncryptUpdate(ctx, ciphertext, &len, plaintext, plaintext_len);

    ciphertext_len = len;
    EVP_EncryptFinal_ex(ctx, ciphertext + len, &len);
    ciphertext_len += len;
    EVP_CIPHER_CTX_free(ctx);
    return ciphertext_len;
}`

дешифрование

int
aes_decrypt(unsigned char *ciphertext, int ciphertext_len, unsigned char *key,
unsigned char *iv, unsigned char *plaintext){
    EVP_CIPHER_CTX *ctx;
    int len;
    int plaintext_len;

    ctx = EVP_CIPHER_CTX_new();
    EVP_DecryptInit_ex(ctx, EVP_aes_128_ecb(), NULL, key, iv);
    EVP_DecryptUpdate(ctx, plaintext, &len, ciphertext, ciphertext_len);

    plaintext_len = len;

    EVP_DecryptFinal_ex(ctx, plaintext + len, &len);
    plaintext_len += len;

    EVP_CIPHER_CTX_free(ctx);

    plaintext[plaintext_len] = '\0';

    return plaintext_len;
}
...