首页 > 其他分享 >Django接入谷歌Authenticator的一次简单尝试

Django接入谷歌Authenticator的一次简单尝试

时间:2024-09-26 17:57:23浏览次数:10  
标签:一次性 self 谷歌 Django Authenticator 密码 secret

authenticator解决了什么问题

1,authenticator是什么?

谷歌Authenticator是谷歌推出的一种双因素身份验证应用程序,它是一种为用户提供额外层次的账户保护的安全工具.传统的认证方式通常只依赖于用户名和密码,而双因素身份验证则需要用户提供两个不同类型的验证信息,以增加账户的安全性.

谷歌Authenticator通过生成动态的一次性密码来实现双因素身份.当你登录一个已启用谷歌Authenticator的系统或服务时,需要输入用户名和密码,然后打开Authenticator应用来获取当前的一次性密码,这个密码每30秒更新一次,只在短暂的时间段内有效.

这种一次性密码是通过基于时间戳的算法计算得出的,同时还需要通过与账号绑定的密码进行验证.由于每个密码只在极短的时间内有效,并且密码是动态变化的,即使有人获得您的用户名和密码,他们也我无法成功登录您的账户,因为他们没有有效的一次性密码.

谷歌Authenticator还可以与多个账户关联,这意味着您可以在一个应用中管理多个账户的一次性密码,它对于保护您的各种在线账户非常有用.简而言之,谷歌Authenticator是一种提供额外层次安全保护的双因素身份验证应用程序,它通过生成动态的一次性密码来增加账户的安全性,并在登录过程中要求用户提供额外的验证信息.


2,它本质上解决了什么问题?


  • 强化账户安全性:谷歌Authenticator提供了一种额外的身份验证层,以保护您的账户免受未授权的访问.即使有人获取您的用户名和密码,他们仍然需要有效的一次性密码才能成功登录.
  • 降低密码泄露风险:由于谷歌Authenticator生成的一次性密码在每30秒钟更新一次,并且只在特定的时间段内有效,即使密码泄露,公鸡者也只能在一个非常短的时间窗口内进行利用,这大大降低了密码被滥用的风险.
  • 抵御钓鱼和网络针对性公鸡:通过生成每30秒钟更改的动态一次性密码,谷歌Authenticator防止了恶意用户和公鸡者使用被窃取的认证凭据进行登录.这增加了实施钓鱼和网络针对性公鸡的难度.
  • 提供离线身份验证:由于一次性密码是基于时间戳计算的,所以即使在没有网络连接的情况下,您仍然可以进行身份验证,这对于旅行,临时网络中断或无法接收短信验证码的情况非常有用.


二,authenticator的原理

1,基于时间的TOTP

谷歌Authenticator是基于TOTP算法实现的验证方式,TOT是谷歌Authenticator中使用的一种身份验证方法,它基于时间的动态密码算法,用于生成一次性密码.

当未特定用户开启谷歌Authenticator时,它会与该账户关联一个密钥(这个密钥和用户绑定关系数据可以存进mysql或者redis中),每30秒钟,该密钥都会与当前时间戳进行计算,并生成一个新的一次性密码.

当您需要进行身份验证时,您可以打开谷歌Authenticator应用程序,输入相关账户的用户名,然后应用程序会基于与服务器同步的时间戳生成相应的一次性密码.您将次密码输入到身份验证页面或应用程序中,以确认您是合法用户.


2,认证流程

Django接入谷歌Authenticator的一次简单尝试_谷歌Authenticator



3,python代码实现

1,生成随机密钥并与用户进行绑定bind,同时还具有解绑动作

 # 随机生成一个base32密钥
  def random_base32(self, length=32, random=_random.SystemRandom(),
                    chars=None):
    if chars is None:
      chars = list('ABCDEFGHIJKLMNOPQRSTUVWXYZ234567')
      return ''.join(
        random.choice(chars)
        for _ in range(length)
      )
 
def bind(username, randomsk):
   login2_secret = cache.get(username)
   if not login2_secret:
      cache.set(username, login2_secret)

def unbind(username):
   login2_secret = cache.get(username)
   if login2_secret:
      cache.delete(username, login2_secret)

2, 根据绑定的密钥生成qr二维码

  # 生成二维码地址
    def getQRCodeGoogleUrl(self, name, secret):
        """
        :param self:
        :param name:  用户名
        :param secret: 秘钥
        :return:
        """
        print(self)
        return "otpauth://totp/" + name + "?secret=%s" % secret
 
    # 生成二维码base64格式
    def genQr64(self, url):
        print(self)
        # 原文链接:https: // blog.csdn.net / weixin_44070137 / article / details / 107097403
        qr = qrcode.make(url)
        buf = io.BytesIO()
        qr.save(buf)
        img_buf = buf.getvalue()
        img_stream = base64.b64encode(img_buf)
        return img_stream

3, 根据绑定的密钥生成动态密码列表

def byte_secret(self, secret):
        print(self)
        missing_padding = len(secret) % 8
        if missing_padding != 0:
            secret += '=' * (8 - missing_padding)
        return base64.b32decode(secret, casefold=True)
 
def int_to_bytestring(self, i, padding=8):
    print(self)
    result = bytearray()
    while i != 0:
        result.append(i & 0xFF)
        i >>= 8
        return bytes(bytearray(reversed(result)).rjust(padding, b'\0'))

 # 根据约定的密钥计算当前动态密码
def generate_otp(self, secret, timestamp=None):
    if not timestamp:
        timestamp = datetime.datetime.now()
        for_time = timestamp
        i = time.mktime(for_time.timetuple())
        intput = int(i / 30)
        digest = hashlib.sha1
        digits = 6
        if intput < 0:
            raise ValueError('input must be positive integer')
            hasher = hmac.new(self.byte_secret(secret), self.int_to_bytestring(intput), digest)
            hmac_hash = bytearray(hasher.digest())
            offset = hmac_hash[-1] & 0xf
            code = ((hmac_hash[offset] & 0x7f) << 24 |
                    (hmac_hash[offset + 1] & 0xff) << 16 |
                    (hmac_hash[offset + 2] & 0xff) << 8 |
                    (hmac_hash[offset + 3] & 0xff))
            str_code = str(code % 10 ** digits)
            while len(str_code) < digits:
                str_code = '0' + str_code
                return str_code
 
def get_code(self, sKey):
    """
        使用说明
        使用random_base32 生成 密钥 sKey
        使用generate_otp(sKey) 生成 code 时间戳默认为当前,一般情况要传递30s 60s 90s 120s 之前 共计五个时间戳来生成code
        """
    print(self)
    now = datetime.datetime.now()
    now_30s = now - datetime.timedelta(seconds=30)
    now_60s = now - datetime.timedelta(seconds=60)
    now_90s = now - datetime.timedelta(seconds=90)
    now_120s = now - datetime.timedelta(seconds=120)
    code_list = [self.generate_otp(sKey, now),
                 self.generate_otp(sKey, now_30s),
                 self.generate_otp(sKey, now_60s),
                 self.generate_otp(sKey, now_90s),
                 self.generate_otp(sKey, now_120s)]
    return code_list

4,验证一次性密码方法

def verify_code(self, two_code, sKey):
    """
        验证二次登录验证码
        """
    if two_code in self.get_code(sKey):
        return True
    else:
        return False

标签:一次性,self,谷歌,Django,Authenticator,密码,secret
From: https://blog.51cto.com/u_15703497/12120327

相关文章

  • 基于Django的农业害虫识别系统设计与实现
    文章目录前言一、详细操作演示视频二、具体实现截图三、技术栈1.前端-Vue.js2.后端-SpringBoot3.数据库-MySQL4.系统架构-B/S四、系统测试1.系统测试概述2.系统功能测试3.系统测试结论五、项目代码参考六、数据库代码参考七、项目论文示例结语前言......
  • 怎么查看网站是否被谷歌收录,怎么查看网站是否被谷歌收录的办法
    要查看网站是否被谷歌收录,可以采用以下几种办法:一、使用谷歌搜索引擎的“site:”指令这是最直接且常用的方法之一。具体步骤如下:打开谷歌搜索引擎:在浏览器中打开Google.com,确保使用的是谷歌的官方搜索引擎。输入查询指令:在搜索框中输入“site:”加上你的网站域名,注意使用英文......
  • 基于django+vue智能出行系统设计与实现【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着城市化进程的加速和居民生活水平的提高,交通出行已成为现代社会不可或缺的一部分。然而,传统出行方式面临着交通拥堵、资源浪费、环境污......
  • 基于django+vue在线视频网站【开题报告+程序+论文】-计算机毕设
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着互联网技术的飞速发展和宽带网络的普及,视频内容已成为人们日常生活中不可或缺的一部分。在线视频网站作为数字时代的重要产物,不仅为用......
  • 基于django+vue在线家庭语数外作业系统的设计与实现【开题报告+程序+论文】-计算机毕
    本系统(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。系统程序文件列表开题报告内容研究背景随着互联网技术的飞速发展和教育信息化的不断深入,传统教育模式正逐步向更加灵活、高效的在线教育模式转变。在家庭教育中,家长往往面临辅导......
  • (免费源码)计算机毕业设计必看必学 原创定制程序 java、PHP、python、小程序、文案全套
    摘 要随着社会的快速发展和人们生活水平的不断提高,旅游已逐渐成为人们生活的重要组成部分,用户能够获取旅游信息的渠道也随信息技术的广泛应用而增加。大量未经过滤的信息在展示给用户的同时,也淹没了用户真正感兴趣的信息。为了方便用户快速定位自己感兴趣的信息,个性化旅游......
  • django数字化时代的新能源汽车供应链优化与可视化-计算机毕业设计源码91188
    摘要本研究旨在探讨利用Django框架进行新能源汽车供应链优化与可视化的应用。随着数字化时代的到来,新能源汽车产业迅速发展,供应链管理变得至关重要。通过结合Django框架的强大功能,我们可以优化新能源汽车供应链的各个环节,实现供需匹配的精准管理,同时利用可视化技术展示供应链......
  • django点名气象数据分析系统---附源码66265
    目录摘 要第1章 绪 论1.1研究背景与意义1.2 项目背景1.3研究方法和技术第2章 系统分析2.1可行性分析2.2系统流程分析2.2.1数据增加流程2.2.2数据修改流程2.2.3数据删除流程2.3 系统功能分析2.3.1功能性分析2.3.2非功能性分析2.4......
  • [含文档+PPT+源码等]精品基于Python实现的django校园流浪猫救助平台的设计与实现
    软件开发环境及开发工具:开发语言:python使用框架:Django前端技术:JavaScript、VUE.js(2.X)、css3开发工具:pycharm、VisualStudioCode、HbuildX数据库:MySQL5.7.26(版本号)数据库管理工具:phpstudy/Navicat或者phpstudy/sqlyogpython版本:python3.0及以上浏览器:谷歌浏览器基......
  • Google Earth Pro(谷歌地球)安装教程
    软件:GoogleEarthPro7.3.6语言:简体中文大小:55M安装环境:Win7及以上操作系统下载夸克网盘丨下载链接:夸克网盘分享1.把资源从网盘下载到电脑上面,右键压缩包选择解压到当前文件夹。2.打开解压后的文件夹,鼠标右击【Setup】选择【以管理员身份运行】。3.取消勾选【在安装后......