0

问题

我需要为 Django 项目实现双重身份验证。我正在使用Django 双因素身份验证,它在本地与 Google Authenticator 和我们的 SMS 网关一起工作得很好。当我将应用程序发布到测试服务器时会出现此问题。登录正常工作,但是当我填写令牌时,它只会将我重定向回初始登录步骤以再次填写我的凭据。它没有在 UI 中给我任何错误消息,据我所知,日志中也没有。

不知道它是否相关,但该应用程序在服务器上作为 Docker Swarm 服务运行。

我试过的

由于缺乏对 2FA 库和 OTP 库的反馈和知识,我真的不知道从哪里开始。我很确定我的本地机器和测试环境之间的设置一样好。软件包版本相同。我什至确保我的机器和服务器之间的时间和时区是相同的。

在 OTP 库的表中查看数据库,失败计数为 0,并且last_t每次我尝试登录时都会增加。这告诉我,令牌本身已经过验证,根据 Django-OTP 文档:

BigIntegerField:最后验证令牌的时间步长。为了避免两次验证相同的令牌,这将在每次成功验证时更新。随后将仅验证更高时间步的令牌。(默认值:-1)


任何建议都非常感谢。我知道我没有提供我的确切实现的具体细节,但我希望有人可能对问题可能有一些大致的了解。无论如何,如果您需要更具体的内容,请告诉我。

谢谢,

尼克诺

编辑 1

我错了,日志中实际上有一些我以前没有看到的东西:

Requested step 'token' is no longer valid, returning to last valid step in the wizard.

所以也许这可以表明我有一些漂移导致令牌无效?

版本是

  • Django 2.2.20
  • django-otp 1.0.3
  • django-双因素身份验证 1.13.1

我将尝试包含相关代码

我的settings.py被分成环境设置,每个settings.base.py。2FA 的所有相关代码都在 settings.base.py 中:

ISTALLED_APPS = [
    ...
    'django_otp',
    'django_otp.plugins.otp_static',
    'django_otp.plugins.otp_totp',
    'two_factor'
]

MIDDLEWARE = [
    ...
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django_otp.middleware.OTPMiddleware',
    ...
]

LOGIN_URL = 'two_factor:login'

# Not sure if these are relevant
TIME_ZONE = 'Europe/Oslo'

USE_I18N = True

USE_L10N = True

USE_TZ = True

这基本上是我添加的所有内容,以便使其在我的机器上本地工作。

4

1 回答 1

0

在我的更新中发现日志行给了我一些东西给谷歌,我发现了这个:https ://github.com/Bouke/django-two-factor-auth/issues/65#issuecomment-57931565

所以会发生什么情况是浏览器要求 favicon.ico 未在我的登录豁免 url 中列出,因此请求被重定向到登录页面,这使实际屏幕上的初始登录无效。

不知道为什么这没有在本地发生,但可能与开发服务器有关......无论如何它现在正在工作!

于 2021-04-12T17:56:27.813 回答