gpt4 book ai didi

c++ - 使用 GPGME 加密灵活的数据量

转载 作者:行者123 更新时间:2023-11-28 05:52:27 25 4
gpt4 key购买 nike

我目前正在编写一个 C++ 应用程序,并且想使用 GPGME 进行消息签名、加密和 key 管理。我知道我可以用这种方式加密数据:

    err = gpgme_op_encrypt(mContext, recipients,...);
if(err) {
// .. error handling
}
result = gpgme_op_encrypt_result(mContext);
if(result->invalid_recipients){
//error handling
}

nbytes = gpgme_data_seek(encrypted_text, 0, SEEK_SET);
if(nbytes == -1) {
//error handling
}
buffer = malloc(MAXLEN);
nbytes = gpgme_data_read(encrypted_text, buffer, MAXLEN);

但正如您所见,我必须使用 MAXLEN 作为读取缓冲区中加密数据的限制。有没有办法提前确定我的加密数据结果多长时间(给定明文)?还是我必须接受静态限制?

最佳答案

我不熟悉这个特定的 API,但是 gpgme_data_seekgpgme_data_read 调用看起来它们可能表现得像 read()seek() 来自文件 I/O 系统。

(1) 尽可能多地分配缓冲区(假设为 N)。

(2) 调用n=gpgme_data_read(...,N)直到N!=n

(3) 检查错误条件(我猜是n<0)

继续,直到您处理完所有感兴趣的数据。

关于c++ - 使用 GPGME 加密灵活的数据量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34946861/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com