openssl AES c

#include <openssl/aes.h>
int main(void) {

    #define AES_SIZE_BIT    256

    unsigned char keys[AES_SIZE_BIT / 8 + 1];
    unsigned char buff[1024];
    unsigned char encodes[1024];

    int len = 0;

    memset(buff, 0, sizeof(buff));
    memset(keys, 0, sizeof(keys));
    memset(encodes,0,sizeof(encodes));

    strcpy((char*) keys, "password");
    strcpy((char*) buff, "Hello world!");

    if (strlen((char *) buff) % AES_BLOCK_SIZE == 0) {  /*//aes加密数据输入/输出长度必须是16的倍数*/
        len = strlen((char *) buff) + 1;
    } else {
        len = ((strlen((char *) buff) + 1) / AES_BLOCK_SIZE + 1)
                * AES_BLOCK_SIZE;
    }
    log_d("len=%d", len);

    {
        uint8_t iv[] = { 0xA, 1, 0xB, 5, 4, 0xF, 7, 9, 0x17, 3, 1, 6, 8, 0xC,
                0xD, 91 };
        AES_KEY aes;
        AES_set_encrypt_key(keys, AES_SIZE_BIT, &aes);
        AES_cbc_encrypt(buff, encodes, len, &aes, iv, AES_ENCRYPT);
        log_hex(encodes, 100, "encode:");
    }
    log_d("Key:%s", keys);
    {
        uint8_t iv[] = { 0xA, 1, 0xB, 5, 4, 0xF, 7, 9, 0x17, 3, 1, 6, 8, 0xC,
                0xD, 91 };
        log_hex(iv, 16, "iv:");
        unsigned char decods[1024];

        memset(decods, 0, sizeof(decods));

        AES_KEY aes;
        AES_set_decrypt_key(keys, AES_SIZE_BIT, &aes);  //AES_SIZE_BIT: 128/256
        AES_cbc_encrypt(encodes, decods, len, &aes, iv, AES_DECRYPT);  //len: %16==0, iv-len=AES_BLOCK_SIZE=16

        log_d("%s", decods);
    }

    return EXIT_SUCCESS;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值