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
    • 最新
    • 标签
主页 / unix / 问题 / 755251
Accepted
DumbQuestion
DumbQuestion
Asked: 2023-08-30 00:02:10 +0800 CST2023-08-30 00:02:10 +0800 CST 2023-08-30 00:02:10 +0800 CST

将加密并签名的消息转换为刚刚签名的 PGP 消息

  • 772

假设鲍勃从爱丽丝那里收到一条用他的公钥加密并用她的私钥签名的消息。现在他想向查理证明他收到了她发来的消息,内容与此完全相同。该消息是通过创建的gpg --sign --encrypt。

我的想法是他可以解密该消息并将其及其签名保存在某处,但我找不到实现此目的的方法。但由于 GPG 对消息进行签名,然后对其进行加密,因此这至少在理论上是可能的。

现在他该如何做到这一点,或者您是否有任何其他想法,鲍勃如何向查理证明消息的真实性?

限制:

  • 向查理·鲍勃提供私钥(显然)不是一个选择。
  • 只能通过电子邮件进行沟通。
  • 无法再联系到 Alice,因此重新发送消息或 Charlie 和 Alice 无法相互通信。鲍勃必须利用他已有的东西。
encryption
  • 1 1 个回答
  • 34 Views

1 个回答

  • Voted
  1. Best Answer
    minorChaos
    2023-08-30T05:08:27+08:002023-08-30T05:08:27+08:00

    这是很难找到的。它不在本地man gpg。

    命令:

    gpg -vi    --unwrap  msg1.gpg 
    

    (-v意味着详细,-i是交互式的,不会覆盖文件。)

    警告:有时您可能(?)需要解压缩输出。

    文档: https: //gnupg.org/documentation/manuals/gnupg.pdf

    --unwrap This command is similar to ‘--decrypt’ with the difference that the output
    is not the usual plaintext but the original message with the encryption layer
    removed. Thus the output will be an OpenPGP data structure which often
    means a signed OpenPGP message. Note that this option may or may not
    remove a compression layer which is often found beneath the encryption layer.
    

    测试(在 Ubuntu 上,2023 年 8 月更新)。

    ### Alice(=testS) signed a message and encrypted it
    ### using Bobs(=test) public key. -r means --recipient
    
    [0] $ echo A message to be signed a sent > message
    [0] $ gpg  -u testS  -r test    --sign --encrypt  message 
    
     ## Alice sent  message.gpg  to Bob
    
    [0] $ gpg -vi    --unwrap  message.gpg    # --output ...
    gpg: WARNING: no command supplied.  Trying to guess what you mean ...
    gpg: public key is 3DF37C69945F312D
    gpg: using subkey 3DF37C69945F312D instead of primary key 96B43A891E43F2F4
    gpg: using subkey 3DF37C69945F312D instead of primary key 96B43A891E43F2F4
    gpg: encrypted with 3072-bit RSA key, ID 3DF37C69945F312D, created 2023-08-29
          "TEST TE <[email protected]>"
    gpg: AES256 encrypted data
    File 'message' exists. Overwrite? (y/N) n
    Enter new filename: message-only-singed.gpg
    
    ## Bob sends "unwrapped" (=deciphered) file   message-only-signed.php
    ## to Charlie
     
    [0] $ gpg -d  message-only-singed.gpg      
    A message to be signed a sent               <---- The message
    gpg: Signature made Tue 29 Aug 2023 22:55:11 CEST
    gpg:                using RSA key 6646102A06EC96A49AE8828FCDF0F02D337492DD
    gpg:                issuer "[email protected]"
    gpg: Good signature from "tests <[email protected]>" [ultimate]   <---- the sig
    
    ### Charlie sees that  Alice=testS    signed the message
     
    

    (最后一个命令可以与 一起使用--output file。)

    • 1

相关问题

  • 从我的 SSH 配置中完全删除 RSA 密钥对的正确方法是什么?

  • dmsetup luksFormat 创建对齐不一致

  • dm-crypt / cryptsetup 使用哪个块加密维度

  • 如何使用 pv 显示 openssl 加密/解密的进度?

  • 对 openssl 加密文件中的盐感到困惑

Sidebar

Stats

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

    模块 i915 可能缺少固件 /lib/firmware/i915/*

    • 3 个回答
  • Marko Smith

    无法获取 jessie backports 存储库

    • 4 个回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    user12345 无法获取 jessie backports 存储库 2019-03-27 04:39:28 +0800 CST
  • Martin Hope
    Carl 为什么大多数 systemd 示例都包含 WantedBy=multi-user.target? 2019-03-15 11:49:25 +0800 CST
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

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

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve