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])) & 15
    code = str((struct.unpack(">I", code[o:o + 4])[0] & 0x7fffffff) % 1000000)
    code = '0' * (6 - len(code)) + code  # 如果安全码不足6位, 补齐至6位
    return code


def 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/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山水好风光

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值