我目前正在编写一个C++应用程序,并希望使用 GPGME 进行消息签名、加密和密钥管理。我知道我可以这样加密数据:
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 作为读取缓冲区中加密数据的限制。有没有办法确定我的加密数据结果将提前多长时间(给定 plaintex)?还是我必须接受静态限制?
我不
熟悉这个特定的 API,但gpgme_data_seek
和gpgme_data_read
调用看起来就像文件read()
和seek()
文件I/O系统的行为。
1)简单地分配尽可能多的缓冲区(假设N)。
(2) 呼叫n=gpgme_data_read(...,N)
直到N!=n
。
3)检查错误条件(我的猜测是n<0)
继续操作,直到您处理完您感兴趣的所有数据。