导出并保存 GPG 公密钥

GPG 是开源免费的身份验证工具,简单一句话就是对于公钥使用者可以和密钥拥有者秘密通信;对于密钥使用者,可以像外界证明某句话是你说的;在现实场景中,你可以写了一份信,但是大家怎么知道这份信是你写的呢?如果你身边有熟悉你的人,那 TA 可以通过你的笔迹或者你家生产的信纸来知道这份信是你的,但是对于别人呢?他们对你不了解,所以他们很难证明:你就是你?

在程序的世界里,你身边都是陌生人,怎么证明你就是你?一般都使用公钥私钥的非对称加密算法。在网上有很多关于 GPG 和 Github 结合的说明,比如 GitHub 官网的 Doc; 最重要的另一件事是备份你的公钥和密钥。

shell

❯ gpg --list-secret-keys --keyid-format LONG
/Users/c4/.gnupg/pubring.kbx
----------------------------
sec   rsa4096/XXXXXXXXXXXXXX 2021-04-10 [SC]
      XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
uid                 [ 绝对 ] user(仅用来签名 git, message) <user@email.com>
ssb   rsa4096/202XXXXXXXXXXXXX 2021-04-10 [E]

sec 下面的第二行 也就是所有字符都是 X 的那一行就是 keyId;

shell

❯ gpg -a -o public-file.key --export keyId

-a 为 –armor 的简写,表示密钥以 ASCII 的形式输出,默认以二进制的形式输出;

-o 为 –output 的简写,指定写入的文件;

导出会有一个 public-file.key 在当前目录下生成,里面存放你的公钥。

shell

❯ gpg -a -o private-file.key --export-secret-keys keyId

导出一个私钥 private-file.key.

shell

❯ gpg --import xxxx.key

xxxx.key 可以是公钥,也可以是私钥。

公钥可以放在自己的网站或者信任的服务器上,但是私钥一定要自己保管,千万千万不能泄漏出去。否则在计算机的世界里,人人都可以是你。

推荐将你的公钥和私钥都保存在像1password, lastpassword 或者Bitwarden里,我用的是 bitwarden; 因为不能存文件,只能将公钥和私钥的内容复制并拷贝进去。但效果是一样的。

在设置了强密码的前提下, 我们可以稍微的牺牲一些安全性, 通过配置 gpg-agent 的 default-cache-ttl, 让我们解密后的私钥在内存中存在的时间稍微长一些(默认 10 分钟), 比如, 一天:

shell

#~/.gnupg/gpg-agent.conf

default-cache-ttl-ssh 86400

max-cache-ttl-ssh 86400

将公钥发送到 CA 管理中间机构,方便别人验证。

shell

❯ gpg -k
/Users/c4/.gnupg/pubring.kbx
----------------------------
pub   rsa4096 2021-04-11 [SC]
      3D4DC54CDDA6FAFDD13A4970D18Axxxxxxxxxx
uid           [ 绝对 ] guzhongren (used for git&message) <guzhongren@live.cn>
sub   rsa4096 2021-04-11 [E]

❯ gpg --send-key 3D4DC54CDDA6FAFDD13A4970D18Axxxxxxxxxx

你的私钥差不多就是计算机世界里的另一个你,所以,把你自己保护好。

本文仅代表个人观点,与 Thoughtworks 公司无任何关系。


谷哥说-微信公众号

SHA256 checksum: f2fe1394e4ab9297ed69ff73ac32e9ac1375f01c2102183b509bf9379a5995d6

PayForGuzhongren

SHA256 checksum: 964978ecd2059064abe542e51dc02e204d3ee2e6c320ca68e2b1399ce0c6953c

使用此 文件 进行校验: gpg --verify PayForGuzhongren.svg.sig