data:image/s3,"s3://crabby-images/65f74/65f7497fc849bb0052d4db51b57764d9e6be6792" alt="image.png"
前言
为 Git 设置一个 GPG 密钥后,将在每次 Commit 时确认你配置的密码,并在 GitHub 的 Commit 中显示 Verified
标识,以此标记这个 Commit 确实是由你本人完成的,而不是其他人的假冒。
data:image/s3,"s3://crabby-images/01f99/01f99f253ae99a18d70eec9a80aa4dc47fab266c" alt="image.png"
教程
系统环境
操作系统版本:Windows 10 X64
使用的IDE:Intellij IDEA
安装
点击这里下载并安装GPG工具,按照下图中指示下载安装程序
data:image/s3,"s3://crabby-images/256bb/256bb1ed5913a05cc4c22f571795ccbf2dbb9a1e" alt="image.png"
data:image/s3,"s3://crabby-images/20b2c/20b2c6d978012436e6fd73547f135469c333cfed" alt="image.png"
data:image/s3,"s3://crabby-images/01f08/01f08dde3ad10e1a599d21a459fdb00775c1e946" alt="image.png"
生成一个新的密钥
首先,我们需要生成一个带有个人信息的 GPG 密钥。
生成密钥
1gpg --full-generate-key
- 首先 GPG 会询问生成何种加密类型的密钥,
直接按回车
,默认 RSA and RSA 方式即可
- 询问密钥位数,
输入 4096 后按回车
(GitHub 仅接受 4096 位及以上的位数,安全性更强)
- 询问密钥的过期时间,我们一般是不希望密钥过期的,
直接按回车
默认不过期即可
- 询问 “Is this correct?”确认信息输入无误后,
输入 y 并回车
data:image/s3,"s3://crabby-images/2f0b4/2f0b4ee475de926c7b54ad5d3f6c84b22e95f21a" alt="image.png"
输入个人信息
确认信息无误后,还需要一些你的个人信息。
- 询问
Real name
,填写你的英文名后回车提交即可(可以和 GitHub 的用户名不同)
- 询问
Email address
,一定要填写在你的 GitHub 中认证过的邮箱地址
- 询问
Comment
,备注,填写 GitHub Key
(随便填都可以)
- 按 o (英文字母)并回车,保存更改
data:image/s3,"s3://crabby-images/8c418/8c418e5d3f65d144907cc4986a58a81a699a0fcc" alt="image.png"
设置密码
在设置个人信息后,你的电脑会弹出一个密码输入窗口,输入两次相同的密码,为密钥设置密码(一定要记住密码)
data:image/s3,"s3://crabby-images/d156f/d156fc4c2ecc1eb25873016a2c09b00bcd2bb221" alt="image.png"
生成完毕
等待证书生成完成(如果生成的很慢,可以在终端里随便按一些英文字母,随便滑两下鼠标,给密钥生成提供一些随机熵)
data:image/s3,"s3://crabby-images/cd0d4/cd0d43b6b1b0d43568367502bbe201aac100b699" alt="image.png"
将密钥绑定至 GitHub
输入命令获取你的 GPG Key ID
1gpg --list-secret-keys --keyid-format LONG
找到 uid
行和你刚刚设置的信息相同的字段,在 uid
行的上一 sec
行找到你的 GPG Key ID,本次实验的 GPG Key ID 为 58F7B5539BF1B95B
,记住它,一会我们要用到几次
data:image/s3,"s3://crabby-images/b9869/b986967826e54ae206d1061f5cdef4184530e755" alt="image.png"
导出完整公钥
使用命令
1gpg --armor --export [GPG Key ID]
data:image/s3,"s3://crabby-images/05ebe/05ebe97ecc4e25b1645ee65a2d84b239e70bc3d3" alt="image.png"
会生成一段很长的公钥内容,将从 -----BEGIN PGP PUBLIC KEY BLOCK-----
开头,以 -----END PGP PUBLIC KEY BLOCK-----
为结尾(包括这两行)的内容复制下来
将公钥放到 GitHub 中
进入 GitHub,访问你的用户设定界面
data:image/s3,"s3://crabby-images/3da58/3da5889aa624cea676adcead6a4b148ca2f7f85c" alt="image.png"
找到 SSH and GPG Keys
选项卡,点击 New GPG key
按钮(不要点错,不要点错,不要点错)
data:image/s3,"s3://crabby-images/c33c7/c33c7ac19f1730a7d38f644efca328e0602e4089" alt="image.png"
粘贴公钥并保存
data:image/s3,"s3://crabby-images/1a079/1a079f339fa6ea98581c17af3b533126d395f0d0" alt="image.png"
data:image/s3,"s3://crabby-images/94c8e/94c8e23fa446f8c8c8841dbfe5399bcd84125805" alt="image.png"
将密钥绑定至本地 Git
IDEA 调用的是本地的 Git,所以将 Git 直接配置好 GPG Key 即可。
确定 Git 设定的邮箱是否正确
使用命令 git config --global user.email
查看当前 git 命令所使用的邮箱地址,如果不对,请使用 git config --global user.email "新的邮箱地址"
进行更新。
data:image/s3,"s3://crabby-images/b14d1/b14d14a57ba88f660c1f39f9ee0b08f87b7b9266" alt="image.png"
为 Git 指定 GPG Key ID
还记得刚刚查询的 GPG Key ID 吗?让 git 知道它该使用这个 GPG Key。
1git config --global user.signingkey [你的 GPG Key ID]
data:image/s3,"s3://crabby-images/19e63/19e63096e647ff8ff967806276e87daa26f68e4c" alt="image.png"
将所有本地 Commit 默认使用 GPG 进行签名
如果不操作本步骤,默认的 commit 还是会直接跳过签名,你可以通过在 commit 时加入 -S
参数来临时使用 GPG 进行签名。
1git config --global commit.gpgsign true
data:image/s3,"s3://crabby-images/6452a/6452ab7f8326ccbd9fdb1e2253c9cf54f34912dd" alt="image.png"
指定 GPG 程序所在位置
Git 每次 commit 需要向 GPG 程序查找你的 GPG Key,由于新版 GPG 程序的程序目录有变更,Git 程序可能会找不到它而报错,使用命令
1git config --global gpg.program "C:\Program Files (x86)\GnuPG\bin\gpg.exe"
data:image/s3,"s3://crabby-images/55ccd/55ccd942b7837e30a011cdfa9f8578239b7c44f9" alt="image.png"
文中设定的 gpg.exe
所在位置可能和你安装的位置不同,请仔细核对后设定。
测试
一切就绪,在你的 IDEA 中进行一次 Commit,并且 Push 到 GitHub 中试试吧:
data:image/s3,"s3://crabby-images/5bfba/5bfbad8f7915e2ed4c6412b545c428a517e0c7cd" alt="image.png"
每次 Commit 都需要验证密钥的密码进行验证:
data:image/s3,"s3://crabby-images/fe64e/fe64e2249a3b29083f8329224d83274ad3b98af8" alt="image.png"
再 Push 到 GitHub 试试看:
data:image/s3,"s3://crabby-images/36ac4/36ac448514cfe5ddda36853121e30b0780f6eb02" alt="image.png"
data:image/s3,"s3://crabby-images/1c39a/1c39ae48077ba9b7da0ba5fd747fb01dd537d33f" alt="image.png"
data:image/s3,"s3://crabby-images/28a36/28a3623bd75801235b59209bad2c745b48595b36" alt="image.png"
加密成功,赞。
后语
官方文档原文:
You can sign your work locally using GPG or S/MIME. GitHub will verify these signatures so other people will know that your commits come from a trusted source. GitHub will automatically sign commits you make using the GitHub web interface.
您可以使用 GPG 或 S/MIME 在本地签名您的作品。GitHub 将验证这些签名,以便其他人知道您的提交来自受信任的来源。GitHub 在您使用 GitHub Web 时将自动对 Commits 进行签名。