c++ - 在键上使用 gpg --list-packets 的输出来获取 mpi 值以生成 s 表达式

标签 c++ c encryption cryptography gnupg

我正在尝试使用 gpg 生成的公钥使用 libgcrypt 进行加密。我在 key 上使用了 list packets 命令来获取 key 的内容,并将 mpi 值解析为一个 s 表达式。因此,当我尝试使用我的公钥对我的 session key 进行编码时,我收到错误消息“S 表达式中的奇数十六进制数”?我认为列表数据包可能会给我没有前导零的十六进制数字?如果是这样,我需要做什么才能获得可以在 libgcrypt 中使用的 mpi 值?

最佳答案

经过 gpg 和 libgcrypt 邮件列表的反复试验和建议后,list packets 命令会截断 mpi 值中的前导零,因此您必须在 mpi 值前加上零:

  • 十六进制字符串的长度为奇数(前面加一个零)或
  • mpi 是一个负值(前面有两个零)。

进一步说明,使用列表数据包来获取 mpi 值是不明智的,因为它不能可靠地获取 mpi 值,因为它应该是一个调试命令,可能会发生变化。我发现获取公钥和私钥的 mpi 值的最佳方法是使用带有 RFC4880 的 export key 命令对其进行解码,从而直接解析 key 的二进制导出。

关于c++ - 在键上使用 gpg --list-packets 的输出来获取 mpi 值以生成 s 表达式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5864365/

相关文章:

c - 是否可以将应用程序数据附加到套接字?

c - 如何使用 FCGI 检测客户端终止的连接?

c++ - 如何在QTableView中显示QAbstractItemModel的子行

c++ - 测试 1 的运行时错误(Codeforces)

c - 有用于 zOS 的 C 调试器吗?

Java JCE 无限强度加密安全策略文件

java - 如何在 C# 中解密 JWE 源(使用 RSA1_5 A256CBC-HS512 加密)?

javascript - javax.crypto 的 JavaScript 替代代码

c++ - 在 CentOS 7 上从源代码构建 TileServer GL

c++ - SetWindowsHookEx 没有调用我的回调?