在C语言中实现AES加密可以使用开源的AES加密库,比如OpenSSL库。下面是一个简单的示例代码,演示如何使用OpenSSL库进行AES加密:
#include#include #include // 加密函数 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加密操作。