github 的 2fa 遇到新问题,验证码无效。

364 天前
 gransh

昨天在公司匆匆设置了下 github 的 2fa ,用的 microsoft authenticator ,并登录成功。Recovery codes 也存了。

回家想想又下了个 google authenticator ,再加一份。此时家里的 github 网页版还不需要登录,扫了码之后发现出的数字验证码和 microsoft 里的不一样,猜测是回家后二维码变了。于是用 microsoft 又扫了一遍,此时两个码一样了。

今天来公司,用了数字验证码发现一直无效,已经让我稍后再试了。

现在不知道什么原因。

1197 次点击
所在节点    GitHub
9 条回复
gransh
364 天前
又换一个 app 在公司电脑上扫了一遍,6 位数字码确实不一样。同一个 github 账户可以有不一样的二维码吗
gransh
364 天前
用这两个 app 的码都无法登录 github mobile
mschultz
364 天前
那个二维码( TOTP secret )只会显示一次。所以如果你想在多个 Authenticators 里保存这个密钥,那么就必须用多个 Authenticators (你的情况是 Microsoft Authenticator 和 Google Authenticator )扫描 **同一个** QR Code 。你也可以截图这个 QR Code 之后扫描(当然,需自行保证截图的安全)。

如果你在公司先设置好了 Microsoft Authenticator 之后点了确认(此时 Microsoft Authenticator 中保存了密钥,我们记为 A );
之后回家又在 GitHub 的设置页面 **再次** 试图设置 2FA ,GitHub 又显示了一个 QR Code ,这次你用 Google Authenticator 扫描了(记为 B ),如果你此时点了确认,那么密钥 A 即失效。

参考文档:

https://docs.github.com/en/authentication/securing-your-account-with-two-factor-authentication-2fa/configuring-two-factor-authentication

> To configure authentication via TOTP on multiple devices, during setup, scan the QR code using each device at the same time or save the "setup key", which is the TOTP secret. If 2FA is already enabled and you want to add another device, you must re-configure your TOTP app from your security settings.
mschultz
364 天前
@mschultz #3

但根据你的描述,你回家后用 Google Authenticator 和 Microsoft Authenticator 都扫描了新的 QR Code ,也就是说此时(如果点了确认的话)两个 App 中保存的都是密钥 B ,也就是最新生效的密钥,所以不应该有问题。所以你无法登入的情况就很奇怪了。

话说你回家后在 GitHub 设置中第二次扫码之后输入 6 位数字点确认了么?
gransh
364 天前
@mschultz 谢谢,找到原因了。第一我不知道那个 edit 每次点后二维码都会变。第二我昨天在家里扫完码可能忘记验证了。
以至于今天闹出两种码都不能登录的乌龙事件。还好有恢复码
NoOneNoBody
364 天前
看到扫两次就觉得奇怪,怎么会扫两次,只能保留二维码另外扫
果然是乌龙
gransh
364 天前
@NoOneNoBody 第一次用这个坑还挺多的,当时就随便弄了一下。回来查了查看大家都弄 2-3 个就又加了一个。
fukhak
363 天前
其實二維碼附近一般也有留一段密鑰方便沒有鏡頭的客戶端使用,有需要多設備/軟件的話可以重用那端字符串新增 2fa ,totp 好像基本只能一帳號一密鑰
另外跨客戶端可以試試密碼管理工具例如 bitwarden keepassxc 保存供多個客戶端使用,而且還能事後恢復密鑰
nothingistrue
363 天前
为了照顾不懂 TOTP 协议,和不知道二维码本质就是一串字符的小白,2fa 的使用方式一般仅提供二维码自动设置,不提供 TOTP 密钥/TOTP 协议 URL 手动设置。然后遇到了不知道密钥可能是动态生成的小白。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/997913

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX