探索2FA双因素认证与TOTP时间同步一次性密码

简介: 本文主要介绍了2FA双因素认证与TOTP时间同步一次性密码

2FA (Two-Factor Authentication) 与 TOTP (Time-Based One-Time Password)

引言

在当今数字化时代,信息安全的重要性日益凸显,传统的单一密码登录方式已经无法满足高效且安全的身份验证需求。因此,双因素认证(2FA, Two-Factor Authentication)应运而生,作为一项关键的安全措施,它要求用户提供两个独立的证明身份的方式,显著提高了账户安全性。其中,基于时间的一次性密码(TOTP, Time-Based One-Time Password)是2FA中的一个重要实现方案。

什么是2FA(双因素认证)

双因素认证(2FA)是一种多层次的身份验证机制,旨在确保只有授权用户能够访问受保护的资源。根据NIST(美国国家标准与技术研究院)的定义,它结合了以下至少两种认证因素:

  1. 知识因素:只有用户知道的信息,如密码、PIN码或者安全问题的答案;
  2. 所有权因素:用户拥有的物理设备或虚拟凭证,如智能手机、USB令牌、短信验证码或生物特征;
  3. 内在因素:用户固有的生物特征,如指纹、面部识别或虹膜扫描。

TOTP(时间同步一次性密码)原理

TOTP 是2FA的一个具体实现,它基于时间的一次性密码算法。在这个机制下,用户和服务器双方共同持有预先共享的秘密密钥。每隔一段固定的时间间隔(通常为30秒),双方都会根据当前时间戳和此密钥通过HMAC(Hash-based Message Authentication Code)算法计算出一个唯一的、短暂有效的动态密码。

工作流程

  1. 密钥生成与存储

    • 用户在启用TOTP时,会生成一个基于特定算法的密钥,并将其保存在服务器端和用户端(通常是手机上的认证APP)。
  2. 时间同步

    • TOTP算法依赖于时间同步,客户端和服务端各自基于当前时间戳计算哈希值。
  3. 密码生成

    • 使用HMAC函数,将当前时间戳与共享密钥相结合生成一个哈希值。
    • 从哈希值中抽取一定长度的数值作为一次性密码。
  4. 验证过程

    • 当用户尝试登录时,在认证APP上获取并输入当前的有效TOTP密码。
    • 服务器同样根据当前时间戳计算TOTP密码,并与用户提交的密码进行比对,如果匹配,则验证成功。

总归来说,使用 TOTP 来进行 2FA 的第一步就是通过 QRCode Server 让跟 Client(App) 约定好一个秘密,之后就都用那个秘密跟接下来的时间来进行 Hash 。我们就按这个流程来评估每个步骤的安全性。

结论

TOTP作为双因素认证的重要组成部分,不仅强化了传统密码体系,而且在实施过程中具有简单易用、成本低廉的特点。随着越来越多的在线服务提供商采用2FA和TOTP,这种基于时间的一次性密码技术已经成为提升账户安全性的主流手段之一。无论是企业级应用还是个人用户,启用TOTP能够有效抵御诸如网络钓鱼、密码猜测等常见安全威胁,保障数字资产和个人信息安全。

目录
相关文章
|
SQL 关系型数据库 MySQL
将MySQL 数据迁移到 PostgreSQL
将MySQL 数据迁移到 PostgreSQL 可以采用以下步骤: 安装 PostgreSQL 数据库:首先,需要安装 PostgreSQL 数据库。可以从官方网站(https://www.postgresql.org/)下载最新版本的 PostgreSQL,并根据官方指南进行安装。 创建 PostgreSQL 数据库:在 PostgreSQL 中创建与 MySQL 数据库相对应的数据库。可以使用 pgAdmin 或命令行工具(如 psql)来创建数据库。例如,如果在 MySQL 中有一个名为 "mydb" 的数据库,那么可以在 PostgreSQL 中创建一个具有相同名称的数据库。 导
4601 0
|
存储 IDE 区块链
《Solidity 简易速速上手小册》第3章:Solidity 语法基础(2024 最新版)
《Solidity 简易速速上手小册》第3章:Solidity 语法基础(2024 最新版)
430 2
|
存储 安全 算法
使用jotp实现双因子验证
扫盲使用totp增强身份安全性指南,原理看懂也不用自己造轮子呀,最讨厌哪些啥也不懂的搬运工,我这里给大家解惑吧
882 0
|
C#
C# 中串口通信 serialport1.DataReceived 函数无法触发或者出发延时等等问题解决方法
原文:C# 中串口通信 serialport1.DataReceived 函数无法触发或者出发延时等等问题解决方法 以前这个问题困扰我多天最后查资料一大堆,最后最终攻克了,看到非常多人做C#串口都遇到相同的问题,所以写一篇博文,以便学习交流。
3686 0
|
安全 网络安全 数据安全/隐私保护
什么是2FA?如何在公共网站上实现2FA?
【8月更文挑战第31天】
2290 0
|
7月前
|
关系型数据库 Linux 数据库
PostgreSQL 入门指南:安装、配置与基本命令
本文从零开始,详细介绍如何在 Windows、Linux 和 macOS 上安装和配置 PostgreSQL,涵盖30+个实操代码示例。内容包括安装步骤、配置远程访问和用户权限、基础数据库操作命令(如创建表、插入和查询数据),以及常见问题的解决方案。通过学习,你将掌握 PostgreSQL 的基本使用方法,并为后续深入学习打下坚实基础。
6999 1
|
8月前
|
自然语言处理 安全 搜索推荐
阿里通义等提出Chronos:慢思考RAG技术助力新闻时间线总结
在数字化时代,新闻信息的指数级增长使得从海量文本中提取和整理历史事件的时间线变得至关重要。为了应对这一挑战,阿里巴巴通义实验室与上海交通大学的中断者提出了一种基于Agent的新闻时间线摘要新框架——CH RONOS,源自希腊神话中的时间之神柯罗诺斯,该框架通过迭代多轮的自我提问方式,结合检索增强生成技术,从互联网上检索相关事件信息,并生成时间顺序的新闻摘要,为新闻时间线摘要生成提供了一种全新的解决方案。
370 44
|
算法 安全 Go
基于TOTP算法的Github两步验证2FA(双因子)机制Python3.10/Golang1.21实现
双因子登录说白了就是通过第三方设备证明"你是你自己"的一个措施,Github官方推荐在移动端下载1Password、Authy、Microsoft Authenticator等APP来通过扫码进行验证,其实大可不必如此麻烦,本次我们通过Python/Golang代码来实现双因子登录验证。
基于TOTP算法的Github两步验证2FA(双因子)机制Python3.10/Golang1.21实现
|
12月前
|
SQL 监控 Oracle
Oracle SQL性能优化全面指南
在数据库管理领域,Oracle SQL性能优化是确保数据库高效运行和数据查询速度的关键
1448 6