AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1493750
Accepted
noideawhattoenter
noideawhattoenter
Asked: 2019-10-19 10:16:14 +0800 CST2019-10-19 10:16:14 +0800 CST 2019-10-19 10:16:14 +0800 CST

如何使用 GPG 从公钥块中获取“用户名”字段?

  • 772

经过这么多小时的努力,我不得不问这个事实已经告诉我,这两个陈述中至少有一个是正确的:

  1. 我正在做一些非常错误的事情。
  2. PGP/GPG 绝对是一团糟,它故意使工作变得尽可能困难和混乱。

基本上,我的系统会自动导入发送给我的任何 PGP 公钥块,以便能够在消息外出时自动加密消息(作为回复发送给我)。

当您使用 PGP/GPG 加密纯文本消息时,您告诉程序使用哪个“接收者”。这个令人困惑的术语实际上是指存储在 GPG 中的公钥中的“全名 + 电子邮件地址”字段(出于某种原因称为“用户名”)。

好吧,当我“导入”这样一个 PGP 公钥块(有效)时,我不知道“用户名”字段是什么,如果我不知道,我实际上无法使用它,因为加密功能要我参考正确的“存储的公钥”。

但是我如何真正从公钥中提取“用户名”字段呢?你会认为当你执行 --import 命令时它会返回这个,但据我所知,它不会。我已经在手册中挖掘了几个小时,却没有找到任何与此相关的内容。

作为记录,我确实找到了这个 StackOverflow 线程:https ://security.stackexchange.com/questions/50965/extracting-the-gpg-userid-from-the-public-key-file ...但它绝对没有对我有感觉。“解决方案”已经知道并指定了某种 id,这似乎违背了整个观点,因为这本质上是我们试图找到的(除了它是“用户名”字段)。

我见过各种“常用/有用的 PGP/GPG 命令”,但没有一个甚至提到过这一点。嗯?这就像最基本也是最关键的任务……我很困惑。为什么 --import 命令不给我任何类型的 id 来使用?是吗,但以某种令人费解的方式?

gnupg pgp
  • 1 1 个回答
  • 4458 Views

1 个回答

  • Voted
  1. Best Answer
    user1686
    2019-10-19T12:03:14+08:002019-10-19T12:03:14+08:00

    为什么 --import 命令不给我任何类型的 id 来使用?是吗,但以某种令人费解的方式?

    确实如此,这主要是您对“可用ID”的期望大多是错误的。

    当您使用 PGP/GPG 加密纯文本消息时,您告诉程序使用哪个“接收者”。这个令人困惑的术语实际上是指存储在 GPG 中的公钥中的“全名 + 电子邮件地址”字段(出于某种原因称为“用户名”)。

    该字段称为“用户 ID”。它不称为“用户名”。

    许多程序(主要是gpg包装它的所有工具)也将仅通过电子邮件地址或用户 ID 的任何其他子字符串匹配或完整的 160 位公钥指纹或“密钥 ID”(32 /64 位截断指纹)。例如:

    gpg --recipient [email protected] --encrypt
    gpg --recipient EA708A76F932CCEAF60D364375F1129BE6E591E4 --encrypt
    gpg --recipient "EA70 8A76 F932 CCEA F60D 3643 75F1 129B E6E5 91E4" --encrypt
    gpg --recipient fred --encrypt
    gpg --recipient 0x75F1129BE6E591E4 --encrypt
    

    (您可以通过将匹配传递给 来测试匹配gpg --list-keys,例如gpg -k fred。)

    其中,通过指纹指定收件人是最安全的选项。“用户 ID”字段(无论是完整的还是部分的)只有在您使用 Web of Trust 或有其他方法来区分合法的“Fred Foobar”密钥和假的“Fred Foobar”密钥时才是安全标识符。

    好吧,当我“导入”这样一个 PGP 公钥块(有效)时,我不知道“用户名”字段是什么,如果我不知道,我实际上无法使用它,因为加密功能要我参考正确的“存储的公钥”。

    GnuPG 总是将此字段显示为gpg --import输出的一部分(以及 64 位“密钥 ID”)。例如:

    $ gpg --status-fd=2 --import < /tmp/test.key
    gpg:密钥75F1129BE6E591E4:公钥“测试用户 <[email protected]> ”已导入
    gpg:处理的总数:1
    gpg:进口:1
    

    要在自动化工具中使用它,请使用--status-fd它为您提供完整的 160 位指纹。例如:

    $ gpg --status-fd=2 --import < /tmp/test.key
    [GNUPG:] IMPORT_OK 0 EA708A76F932CCEAF60D364375F1129BE6E591E4
    [GNUPG:] KEY_CONSIDERED EA708A76F932CCEAF60D364375F1129BE6E591E4 0
    [GNUPG:] IMPORT_RES 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0
    

    如果您正在使用其他一些 PGP 软件(即不是 GnuPG)并且它没有向您显示有关它刚刚导入的密钥的任何信息,那么这是其他 PGP 软件中的 UI 问题。

    • 0

相关问题

  • GPG autologin with pam, pinentry

  • 如何验证我为备份目的导出的 gpg 密钥?

  • gpg-agent: 一个 gpg-agent 已经在运行 - 没有开始一个新的

  • 为什么 Keybase 不在我的 GitHub 证明中包含我的公共 PGP 密钥指纹?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    Windows 10 服务称为 AarSvc_70f961。它是什么,我该如何禁用它?

    • 2 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Marko Smith

    ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] 证书验证失败:无法获取本地颁发者证书 (_ssl.c:1056)

    • 4 个回答
  • Marko Smith

    我如何知道 Windows 安装在哪个驱动器上?

    • 6 个回答
  • Martin Hope
    Albin 支持结束后如何激活 WindowsXP? 2019-11-18 03:50:17 +0800 CST
  • Martin Hope
    fixer1234 “HTTPS Everywhere”仍然相关吗? 2019-10-27 18:06:25 +0800 CST
  • Martin Hope
    Kagaratsch Windows 10 删除大量小文件的速度非常慢。有什么办法可以加快速度吗? 2019-09-23 06:05:43 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    Inter Sys Ctrl+C 和 Ctrl+V 是如何工作的? 2019-05-15 02:51:21 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve