MFA多因素验证

2024-01-21 05:58
文章标签 验证 因素 mfa

本文主要是介绍MFA多因素验证,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

资源后台增加二次认证,提高系统安全性。

原理

要点说明

MFA:即Multi-FactorAuthentication多因素认证,是需要一部智能手机并安装虚拟MFA应用程序即可在账户上加上一层安全保险。 TOTP算法:即Time-Based One-Time Password基于时间的一次性密码,其核心内容包括以下三点:

  1. 共同密钥
  2. 共同时间
  3. 共同签署方法

逻辑说明

  1. 后台生成密钥,然后以二维码形式展示给用户;
  2. 用手机扫码添加MFA账号,生成6位安全码;将安全码添加到网站,确认绑定;
  3. 每次登陆,通过手机获取6位安全码并填写到网站登陆,后台会通过TOTP算法重新生成6位安全码跟页面获取安全码比对验证是否为合法用户。

注意

MFA用户只能绑定一次,手机端MFA账户不能删除;一旦删除需要提工单技术介入处理。

def random_base32(length=16):"""生成共同密钥"""return ''.join(random.choice(chars)for _ in range(length))def get_mfa_code(secret_key):"""生成6位安全码:param secret_key: mfa添加账号时使用的密钥:return:"""interval = int(time.time()) // 30  # 安全码持续时长key = base64.b32decode(secret_key)msg = struct.pack(">Q", interval)code = hmac.new(key, msg, hashlib.sha1).digest()o = ord(chr(code[19])) & 15code = str((struct.unpack(">I", code[o:o + 4])[0] & 0x7fffffff) % 1000000)code = '0' * (6 - len(code)) + code  # 如果安全码不足6位, 补齐至6位return codedef verify_mfa(mfa_code, secret):"""校验安全码是否一致"""return mfa_code == get_mfa_code(secret)

常见(但不局限于)的MFA应用程序:

手机类型MFA应用程序
iPhoneGoogle Authenticator,Eagle 2FA
AndroidEagle 2FA,身份宝,洋葱
Windows Phone身份验证器
BlackberryGoogle Authenticator

参考文档

  1. 阿里云官方文档:https://help.aliyun.com/document_detail/62184.html?spm=a2c4g.11186623.6.721.27d5728517sMbv
  2. google authenticator算法TOTP的python实现:https://yq.aliyun.com/articles/683367/

这篇关于MFA多因素验证的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/628559

相关文章

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

easyui同时验证账户格式和ajax是否存在

accountName: {validator: function (value, param) {if (!/^[a-zA-Z][a-zA-Z0-9_]{3,15}$/i.test(value)) {$.fn.validatebox.defaults.rules.accountName.message = '账户名称不合法(字母开头,允许4-16字节,允许字母数字下划线)';return fal

easyui 验证下拉菜单select

validatebox.js中添加以下方法: selectRequired: {validator: function (value) {if (value == "" || value.indexOf('请选择') >= 0 || value.indexOf('全部') >= 0) {return false;}else {return true;}},message: '该下拉框为必选项'}

web群集--nginx配置文件location匹配符的优先级顺序详解及验证

文章目录 前言优先级顺序优先级顺序(详解)1. 精确匹配(Exact Match)2. 正则表达式匹配(Regex Match)3. 前缀匹配(Prefix Match) 匹配规则的综合应用验证优先级 前言 location的作用 在 NGINX 中,location 指令用于定义如何处理特定的请求 URI。由于网站往往需要不同的处理方式来适应各种请求,NGINX 提供了多种匹

React 笔记 父子组件传值 | 父组件调用子组件数据 | defaultProps | propsType合法性验证

1.通过props实现父组件像子组件传值 、方法、甚至整个父组件 传递整个父组件则   [变量名]={this} import Header from "./Header"render(){return(<Header msg={"我是props传递的数据"}/>)} import React,{Component} from "react";class Header extends

一个图形引擎的画面风格是由那些因素(技术)决定的?

可能很多人第一直覺會認為shader決定了視覺風格,但我認為可以從多個方面去考慮。 1. 幾何模型 一個畫面由多個成分組成,最基本的應該是其結構,在圖形學中通常稱為幾何模型。 一些引擎,如Quake/UE,有比較強的Brush建模功能(或應稱作CSG),製作建築比較方便。而CE則有較強的大型地表、植被、水體等功能,做室外自然環境十分出色。而另一些遊戲類型專用的引擎,例

Java验证辛钦大数定理

本实验通过程序模拟采集大量的样本数据来验证辛钦大数定理。   实验环境: 本实验采用Java语言编程,开发环境为Eclipse,图像生成使用JFreeChart类。   一,验证辛钦大数定理 由辛钦大数定理描述为: 辛钦大数定理(弱大数定理)  设随机变量序列 X1, X2, … 相互独立,服从同一分布,具有数学期望E(Xi) = μ, i = 1, 2, …, 则对于任意正数ε ,

【python因果推断库11】工具变量回归与使用 pymc 验证工具变量4

目录  Wald 估计与简单控制回归的比较 CausalPy 和 多变量模型 感兴趣的系数 复杂化工具变量公式  Wald 估计与简单控制回归的比较 但现在我们可以将这个估计与仅包含教育作为控制变量的简单回归进行比较。 naive_reg_model, idata_reg = make_reg_model(covariate_df.assign(education=df[