EVP_EncryptUpdate用法
时间: 2023-07-25 09:08:50 浏览: 179
EVP_EncryptUpdate是OpenSSL库中的一个函数,用于对数据进行加密。它的用法如下:
```
int EVP_EncryptUpdate(EVP_CIPHER_CTX *ctx, unsigned char *out,
int *out_len, const unsigned char *in, int in_len);
```
其中,参数含义如下:
- ctx:加密上下文,使用EVP_CIPHER_CTX_new函数创建。
- out:存放加密后的数据。
- out_len:加密后数据的长度,调用函数后会更新该值。
- in:待加密的数据。
- in_len:待加密数据的长度。
函数执行后,out缓冲区中存放加密后的数据,out_len中存放加密后数据的长度,如果加密成功则返回1,否则返回0。
需要注意的是,EVP_EncryptUpdate函数只能加密固定长度的数据,如果待加密的数据不是固定长度,则需要多次调用该函数。如果是最后一次调用,则需要调用EVP_EncryptFinal_ex函数来完成加密操作。
示例代码如下:
```
EVP_CIPHER_CTX *ctx;
unsigned char out[1024];
int out_len;
const unsigned char *in = "hello world";
int in_len = strlen(in);
// 创建加密上下文
ctx = EVP_CIPHER_CTX_new();
if (ctx == NULL) {
printf("create encrypt context failed\n");
return -1;
}
// 初始化加密上下文
if (EVP_EncryptInit_ex(ctx, EVP_aes_128_ecb(), NULL, key, iv) != 1) {
printf("initialize encrypt context failed\n");
return -1;
}
// 加密数据
if (EVP_EncryptUpdate(ctx, out, &out_len, in, in_len) != 1) {
printf("encrypt data failed\n");
return -1;
}
// 完成加密操作
if (EVP_EncryptFinal_ex(ctx, out + out_len, &len) != 1) {
printf("finalize encrypt context failed\n");
return -1;
}
// 输出加密后的数据
for (int i = 0; i < out_len + len; i++) {
printf("%02x ", out[i]);
}
printf("\n");
// 释放加密上下文
EVP_CIPHER_CTX_free(ctx);
```
阅读全文