在C语言中实现AES加密可以使用开源的AES加密库,比如OpenSSL库。下面是一个简单的示例代码,演示如何使用OpenSSL库进行AES加密:
#include <stdio.h>
#include <string.h>
#include <openssl/aes.h>
// 加密函数
int aes_encrypt(const unsigned char *plaintext, int plaintext_len, const unsigned char *key, const unsigned char *iv, unsigned char *ciphertext) {
AES_KEY enc_key;
if (AES_set_encrypt_key(key, 128, &enc_key) < 0) {
fprintf(stderr, "AES_set_encrypt_key failed\n");
return -1;
}
AES_cbc_encrypt(plaintext, ciphertext, plaintext_len, &enc_key, iv, AES_ENCRYPT);
return 0;
}
int main() {
unsigned char key[] = "0123456789abcdef"; // 128位密钥
unsigned char iv[] = "0123456789abcdef"; // 初始向量
unsigned char plaintext[] = "Hello, World!";
unsigned char ciphertext[128];
int plaintext_len = strlen(plaintext);
aes_encrypt(plaintext, plaintext_len, key, iv, ciphertext);
printf("Ciphertext: %s\n", ciphertext);
return 0;
}
在上面的示例代码中,我们使用了AES加密的CBC模式进行加密操作。需要注意的是,密钥和初始向量的长度需要根据加密算法的要求来配置,这里我们使用了128位的密钥和初始向量。
使用OpenSSL库进行加密操作需要先安装OpenSSL库,然后在编译时链接OpenSSL库。可以通过以下命令来编译示例代码:
gcc -o aes_encrypt aes_encrypt.c -lcrypto
编译后运行生成的可执行文件即可进行AES加密操作。