完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
描述
打开身份验证器 我总是对这些小型设备感到惊讶。我爸爸用这些来登录他的工作笔记本电脑,我无法理解它如何在没有连接到任何网络的情况下生成代码。 我启动了谷歌并试图搜索它,令人惊讶的是它使用了一个非常惊人的概念。它与服务器有一个共享密钥,然后它对共享密钥和当前 UTC 时间进行了一些计算,以获得一个 6 位数字。因此,远程设备只需要准确计时即可。它使用一种称为 TOTP(基于时间的一次性密码)的算法,它已被标准化,没有必要深入细节,如果有人想看看,这里是标准。 第一个原型 回来,所以我决定使用 ESP32 来实现这个,因为我有一个 devkit,而且 OLED 和 RTC 库是可靠的,我可以使用 WiFi 来获得准确的时间,这绝对需要生成代码,这里有一个第一个原型的图片。 它工作得很好,我曾经从这里生成一个密钥,然后用新密钥和繁荣刷新 esp32,它生成了我想要的代码(这并不像听起来那么容易,我不得不花几天时间整理一个固件来做到这一点,这是 Covid-19 锁定的开始,所以我有很多空闲时间)。 第二个原型 我想把它提升到一个新的水平,制作类似那些 RSA 密钥 ID 设备的东西,但更可配置,而不是像那些一样使用和抛出,而 ESP32 是适合它的工具。所以,我为此设计了一个PCB。这是一个漫长的过程,我不得不处理我的暑期实习,终于在 10 月完成了它的设计,并在两周后再次进行了审查和重新布线。 最终设计 在第二个原型之后,我想让它更时尚,因为 OLED 被用作外部模块并且它增加了太多的高度。所以,我设计了一个新的电路板,基本上通过重新布线和优化来更新电路板设计。您可以看到这两种设计并看到改进。 展示 代码 https://github.com/Open-Authenticator/open-authenticator-app
本帖被以下淘专辑推荐:
|
|
相关推荐
|
|
浏览过的版块 |
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-11-21 23:05 , Processed in 0.826919 second(s), Total 74, Slave 53 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号