GnuPGME: GPG Signature C++
GnuPGME: GPG Signature C++
有人写过关于如何使用GnuPGME的教程或文档吗?这样我就可以在C++中编写gpgSign(std::string fileToBeSigned, std::string outPutFileName)
这样的函数了吗?
下面是一个C示例,带有详细的注释,可以满足您的需求-这不是最直接的方法,但应该说明如何完成文件签名。它不处理签名者的选择,但GPGME文档应该可以帮助您。
您可以直接从命令行保存文件并进行编辑和测试。要进行编译,只需保存为"gpgsign.c",然后执行gcc gpgsign.c -lgpgme -o gpgsign
(注意:必须安装libgpgme)。然后您可以使用gpgsign <input file> <output file>
执行
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <stdlib.h>
#include <errno.h>
#include <locale.h>
#include <gpgme.h>
#define fail_if_err(err)
do {
if (err) {
fprintf (stderr, "%s:%d: %s: %sn",
__FILE__, __LINE__, gpgme_strsource (err),
gpgme_strerror (err));
exit (1);
}
}
while (0)
void gpgSign(const char *fileToBeSigned, const char *outputFileName) {
gpgme_ctx_t ctx;
gpgme_error_t err;
gpgme_data_t in, out;
FILE *outputFile;
int BUF_SIZE = 512;
char buf[BUF_SIZE + 1];
int ret;
/* Set the GPGME signature mode
GPGME_SIG_MODE_NORMAL : Signature with data
GPGME_SIG_MODE_CLEAR : Clear signed text
GPGME_SIG_MODE_DETACH : Detached signature */
gpgme_sig_mode_t sigMode = GPGME_SIG_MODE_CLEAR;
/* Begin setup of GPGME */
gpgme_check_version (NULL);
setlocale (LC_ALL, "");
gpgme_set_locale (NULL, LC_CTYPE, setlocale (LC_CTYPE, NULL));
#ifndef HAVE_W32_SYSTEM
gpgme_set_locale (NULL, LC_MESSAGES, setlocale (LC_MESSAGES, NULL));
#endif
/* End setup of GPGME */
// Create the GPGME Context
err = gpgme_new (&ctx);
// Error handling
fail_if_err (err);
// Set the context to textmode
gpgme_set_textmode (ctx, 1);
// Enable ASCII armor on the context
gpgme_set_armor (ctx, 1);
// Create a data object pointing to the input file
err = gpgme_data_new_from_file (&in, fileToBeSigned, 1);
// Error handling
fail_if_err (err);
// Create a data object pointing to the out buffer
err = gpgme_data_new (&out);
// Error handling
fail_if_err (err);
// Sign the contents of "in" using the defined mode and place it into "out"
err = gpgme_op_sign (ctx, in, out, sigMode);
// Error handling
fail_if_err (err);
// Open the output file
outputFile = fopen (outputFileName, "w+");
// Rewind the "out" data object
ret = gpgme_data_seek (out, 0, SEEK_SET);
// Error handling
if (ret)
fail_if_err (gpgme_err_code_from_errno (errno));
// Read the contents of "out" and place it into buf
while ((ret = gpgme_data_read (out, buf, BUF_SIZE)) > 0) {
// Write the contents of "buf" to "outputFile"
fwrite (buf, ret, 1, outputFile);
}
// Error handling
if (ret < 0)
fail_if_err (gpgme_err_code_from_errno (errno));
// Close "outputFile"
fclose(outputFile);
// Release the "in" data object
gpgme_data_release (in);
// Release the "out" data object
gpgme_data_release (out);
// Release the context
gpgme_release (ctx);
}
int
main (int argc, char **argv) {
if (argc != 3) {
printf("Usage: gpgsign <input file> <output file>n");
exit (1);
}
printf("Signing %s and placing the result into %sn", argv[1], argv[2]);
gpgSign(argv[1], argv[2]);
return 0;
}
这个答案可能来得太晚了,但如果我是你,我宁愿使用Keyczar,这是一个高级加密工具包,带有一个简单的API。提供Java、C++和Python绑定。
对于那些需要加密功能而不需要太多调整的人来说,GPGME仍然是相当低的IMO。当然,加密货币专家需要这种类型的复杂性。
就我个人而言,我尽量避免库要求我在做一些基本的事情之前,在100行样板代码中设置这个引擎和那个上下文。。。但我什么都不是专家。