我试图用加密和解密算法来处理一个问题,我用下面的程序来测试我的需求,我意识到了一个奇怪的问题。
我使用polarssl来满足我的加密和解密需要。
正如你可能首先看到的,我用我的“iv”和“key”加密了“plain”变量,并找到了一个结果。
然后我用“iv”和“key”解密了一个数组。
当我解密“encryptedValue”时,我找到了“plain”数组,但是当我加密“plain”时,我找不到“encryptedValue”。
有什么问题吗?

#include <stdio.h>
#include <polarssl/aes.h>

const int ENCRIPTION = 1;
const int DECRIPTION = 0;

void printByteArray(unsigned char * array, int length) {
    int i = 0;
    for (i = 0; i < length; i++) {
        printf("%x ", array[i]);
    }
    printf("\n");
}

void encrypt() {
    unsigned char o[32];


    unsigned char key[16] = { 0x03, 0xC9, 0xD8, 0xE6, 0x01, 0xA5, 0x05,
            0x9F, 0x11, 0xBF, 0x44, 0x9D, 0xF9, 0x55, 0x18, 0xED

    };

    unsigned char iv[16] = { 0x03, 0xB5, 0x62, 0x57, 0xC8, 0x69, 0x22, 0x89,
            0xF4, 0x96, 0x2B, 0x05, 0x44, 0x2B, 0xD0, 0xA7

    };

    unsigned char plain[32]=
    {
      0xA2, 0xD8, 0x69, 0x9C, 0x77, 0x73, 0xC7, 0x5E, 0x1D, 0x3B, 0x83, 0x26, 0x6E, 0x2F, 0x35, 0x30,
      0x9D, 0xF0, 0xF2, 0xE5, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
    };

    aes_context aesCtx;

    aes_setkey_dec(&aesCtx, key, 128);
    aes_crypt_cbc(&aesCtx, ENCRIPTION, 32, iv, plain, o);

    printf("Encryption result, encrypted value:\n");
    printByteArray(o, 32);
}

decrypt() {

    unsigned char o[32];

    unsigned char key[16] = { 0x03, 0xC9, 0xD8, 0xE6, 0x01, 0xA5, 0x05,
            0x9F, 0x11, 0xBF, 0x44, 0x9D, 0xF9, 0x55, 0x18, 0xED

    };

    unsigned char iv[16] = { 0x03, 0xB5, 0x62, 0x57, 0xC8, 0x69, 0x22, 0x89,
            0xF4, 0x96, 0x2B, 0x05, 0x44, 0x2B, 0xD0, 0xA7

    };

    unsigned char encryptedValue[32] = { 0x11, 0x22, 0x07, 0x86,
            0xA2, 0xD3, 0xED, 0x95, 0xB9, 0x14, 0xC0, 0x57, 0xF7, 0xAF, 0x5F,
            0xDC, 0x93, 0x66, 0x77, 0x68, 0x44, 0x12, 0x9F, 0x1B, 0x72, 0x6A,
            0xEA, 0x51, 0xB8, 0xF7, 0x1D, 0xA4 };

    aes_context aesCtx;

    aes_setkey_dec(&aesCtx, key, 128);
    aes_crypt_cbc(&aesCtx, DECRIPTION, 32, iv, encryptedValue,
            o);

    printf("Decryption result, plain array:\n");
    printByteArray(o, 32);

}

int main() {

    encrypt();
    decrypt();
}

最佳答案

encrypt()函数的这一部分有一个错误:

aes_setkey_dec(&aesCtx, key, 128);
aes_crypt_cbc(&aesCtx, ENCRIPTION, 32, iv, plain, o);

如果您检查API documentation for AES,您将看到有两个不同的函数用于设置加密和解密的密钥。
要设置加密密钥时,应使用aes_setkey_enc()而不是aes_setkey_dec()
然后o中的结果与解密的结果相同。

关于c - 加密解密是不可逆的,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/25160184/

10-11 23:01
查看更多