作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
关闭。这个问题是off-topic .它目前不接受答案。
想改进这个问题? Update the question所以它是on-topic对于堆栈溢出。
8年前关闭。
Improve this question
我读了this article ( archived link ) 很好地解释了如何在 macOS 上设置 PGP。但我打算使用生成的 key 来签署 Git 提交,所以我想我需要将 key 传输到其他计算机。它是否正确?如果是这样,在设备之间传输这些 key 的最佳方式是什么?
最佳答案
是的,您需要转移 key 。 Mac 和 Linux 工作方式相同,将 key 存储在 ~/.gnupg
.传输文件最安全的方法是使用 scp
(ssh的一部分):
scp -rp ~/.gnupg othermachine:
但是,您需要拥有
ssh
先工作。
gpg --export-secret-key
选择性地复制单个 key 和
gpg --import
.如果您对目标计算机具有 ssh 访问权限,则可以使用管道执行此操作,而无需在任何地方存储中间 key :
gpg --export-secret-key SOMEKEYID | ssh othermachine gpg --import
如果您在需要 key 的机器上:
ssh othermachine gpg --export-secret-key SOMEKEYID | gpg --import
如果
gpg
不在远程计算机上的默认位置之一(例如,它在 Mac 上的
/opt/local/bin
中),您必须提供其 ssh 的完整路径,或将其符号链接(symbolic link)到标准位置之一,例如
/usr/local/bin
.
gpg
说“无法打开'/dev/tty'”。如果你用
ssh -t
强制伪终端分配 key 与终端事件混淆,例如密码提示和
\r
s。解决此问题的一种方法是:
ssh othermachine gpg --passphrase-fd 0 --pinentry-mode loopback ...
然后,您需要输入密码并按 Enter。不会有提示,也不会抑制回显(因此密码将在您的终端上可见)。如果您对回声有强烈的感觉,可以使用
stty -echo
暂时关闭它。并再次使用
stty echo
.这可以全部合并到一个命令中,如下所示:
stty -echo; \
ssh othermachine gpg --passphrase-fd 0 --pinentry-mode loopback \
--export-secret-key SOMEKEYID | gpg --import; \
stty echo
但是,您很少需要这样做,因为到目前为止,最常见的情况是当您从您所在的机器导出并导入到您 ssh 到的远程机器上时。
关于encryption - 如何将 pgp 私钥传输到另一台计算机?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3174537/
我是一名优秀的程序员,十分优秀!