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 / 问题 / 1853719
Accepted
Wang
Wang
Asked: 2024-08-27 18:50:00 +0800 CST2024-08-27 18:50:00 +0800 CST 2024-08-27 18:50:00 +0800 CST

在 Thunderbird 中如何使用来自系统 GPG 密钥环的公共密钥 ID?

  • 772

我实际上为我的电子邮件帐户启用了外部 GPG 密钥 ID,因此我可以毫无问题地解密/签名。

但是,我发现现在无法使用系统密钥环中的公钥。今天我发现了这个问题,因为我导入了新密钥。我不记得之前需要做什么特别的事情,但现在显然 Thunderbird 无法看到我的 中的新密钥~/.gnupg。

有没有办法导入所有的公钥?

encryption
  • 1 1 个回答
  • 23 Views

1 个回答

  • Voted
  1. Best Answer
    Preston Maness
    2024-09-21T08:14:35+08:002024-09-21T08:14:35+08:00

    理论上,这是不可能做到的

    目前(或至少截至 2020-12-20),Thunderbird尚未计划与外部/系统 GPG 密钥环集成:

    必须将公钥导入 Thunderbird OpenPGP。没有办法解决这个问题。这是一个设计选择。

    官方常见问题解答也指出:

    我需要同时使用 GnuPG 和 Thunderbird,我可以同步我的密钥吗?

    不可以。目前,Thunderbird 使用自己的密钥副本,不支持与 GnuPG 同步密钥。例外是为智能卡提供的机制,可用于使用 GnuPG 管理的个人密钥。

    您可以通过 中的 OpenPGP 密钥管理器导入较新版本的公钥Tools > OpenPGP Key Manager。如果您已将较新的公钥上传到密钥服务器,您可以尝试Keyserver > Discover Keys Online查看 Thunderbird 是否可以自动导入它。如果您在文件中有更新的公钥,那么您可以使用 导入它File > Import Public Key(s) From File。


    然而...

    现在,我最近(2024-04-12)发现一些迹象,表明可能有一种方法可以让 Thunderbird在启用加密选项的情况下,在您向收件人撰写电子邮件时,自动将公钥从您的外部/系统 GPG 密钥环拉入其自己的密钥存储中:

    为了让 Thunderbird 使用我的 GnuPG 公钥环,我必须在配置编辑器中启用两个选项(Settings -> General -> Config editor):

    mail.openpgp.allow_external_gnupg

    mail.openpgp.fetch_pubkeys_from_gnupg

    现在,Thunderbird 将在需要时从我的 gpg 密钥环导入公钥。

    如果设置了这两个选项,那么“解决”丢失的公钥的方法之一是从外部/系统 GPG 密钥环中提取,这有时似乎有效,有时则无效:

    毕竟,我在“解决…”下有从 gpg 密钥环导入的选项。似乎它对某些密钥有效,对其他密钥无效。它不提供导入过期密钥的功能,这没关系。但也遗漏了一些其他未过期的密钥。似乎共同因素是姓名/电子邮件地址中的非 ASCII 字符,但我还无法确定。无论如何,它会在使用之前将所有公钥导入 Thunderbird 自己的密钥环中。我们最终得到了一个需要同步的重复数据库。真是一团糟……

    我在自己的系统上尝试了此操作,目前运行的是 Thunderbird Beta 131.0b5。它至少看起来是有效的。当我撰写一封电子邮件到带有公钥的地址时,该公钥在我的外部/系统 GPG 密钥环中,但不在 Thunderbird 的密钥存储中,系统会提示我“解决”此问题,并收到几个进一步的提示,最终导入公钥(不是最友好的用户界面,但至少是实用的):

    初始撰写窗口底部有黄色栏,按钮标有“解决...”

    弹出模式表明已找到公钥,但尚未导入,并有另一个按钮标有“解决......”

    相同的模式现在显示带有超链接的密钥指纹,以及密钥来源“GnuPG Keyring”

    另一个弹出模式显示公钥详细信息,其中有多个单选按钮选项用于设置密钥的信任级别。这里选择的是“”。

    最终弹出模式确认密钥已成功导入并可用于签名和加密。“关闭”按钮可见。

    此时,我可以继续写电子邮件并将其以加密形式发送给收件人。


    重要的

    如果电子邮件地址不在您的外部/系统 GPG 密钥环中,则对话框中将没有关于在那里搜索它的选项;只能在线检查或通过文件导入:

    模式指示“没有可用的密钥”,按钮选项为“在线发现公钥...”或“从文件导入公钥...”,并且没有迹象表明已经检查了外部/系统 GPG 密钥环中的电子邮件地址

    mail.openpgp.allow_external_gnupg我认为,如果启用和mail.openpgp.fetch_pubkeys_from_gnupg选项,在 UI 中显示“我们已经检查了您的外部/系统 GPG 密钥环并且没有发现任何东西”会很好。

    这不是一个完美的同步解决方案,但源代码中至少有一些尝试来处理保持外部/系统 GPG 密钥环和 Thunderbird 的密钥存储同步(/mail/extensions/openpgp/content/modules/keyRing.jsm):

    if (
      Services.prefs.getBoolPref("mail.openpgp.allow_external_gnupg") &&
      Services.prefs.getBoolPref("mail.openpgp.fetch_pubkeys_from_gnupg") &&
      !this.alreadyCheckedGnuPG.has(email)
    ) {
      this.alreadyCheckedGnuPG.add(email);
      let keysFromGnuPGMap = lazy.GPGME.getPublicKeysForEmail(email);
      for (let aFpr of keysFromGnuPGMap.keys()) {
        let oldKey = this.getKeyById(aFpr);
        let gpgKeyData = keysFromGnuPGMap.get(aFpr);
        if (oldKey) {
          await this.importKeyDataSilent(null, gpgKeyData, false);
        } else {
          let k = await lazy.RNP.getKeyListFromKeyBlockImpl(gpgKeyData);
          if (!k) {
            continue;
          }
          if (k.length != 1) {
            continue;
          }
          let db = await lazy.CollectedKeysDB.getInstance();
          // If key is known in the db: merge + update.
          let key = await db.mergeExisting(k[0], gpgKeyData, {
            uri: "",
            type: "gnupg",
          });
          await db.storeKey(key);
        }
      }
    }
    
    • 0

相关问题

  • 如何解决:警告:使用过时的密钥推导。使用 -iter 或 -pbkdf2 会更好

  • OpenSSL 支持 ed25519,加密内容?

  • LUKS 模式下 dm-crypt / cryptsetup 的默认加密密钥大小是多少?

  • 备份机密文件的最安全方法,可能没有云存储?

  • 挂载 encfs 目录后看不到文件

Sidebar

Stats

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

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

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

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

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

    • 6 个回答
  • Marko Smith

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

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

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

    • 5 个回答
  • Martin Hope
    Vickel Firefox 不再允许粘贴到 WhatsApp 网页中? 2023-08-18 05:04:35 +0800 CST
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +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
    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