一尘不染

Django AllAuth-如何手动发送重置密码电子邮件?

python

在我的应用程序中,我使用的是Django
Allauth。我没有任何用户注册表格。管理员将通过上传包含用户信息的Excel文件来注册用户。我已完成所有这些操作,并且通过自动生成密码将用户保存在用户表中。上传用户列表并将其保存在数据库中之后,我想向每个用户发送重置密码电子邮件。

在allauth重置密码中,您首先需要进入重置页面account/password/reset/并输入您的电子邮件。然后会发送一封电子邮件,指示您更改密码account/password/reset/key/(?P<uidb36>[0-9A-Za-z]+)-(?P<key>.+)/

是否可以直接在应用程序内发送电子邮件?该URL包含一个我不知道如何生成的密钥!还是有更好的方法做到这一点?


阅读 276

收藏
2021-01-20

共1个答案

一尘不染

这是可能的。我的解决方案实现了一个用户模型post_save信号来调用Allauth密码重置视图,该视图将向用户发送电子邮件。要考虑的第一件事就是让用户的电子邮件地址的管理员用户创建形式强制性的(如解释在这里)。然后使用以下代码:

from allauth.account.views import PasswordResetView

from django.conf import settings
from django.dispatch import receiver
from django.http import HttpRequest
from django.middleware.csrf import get_token


@receiver(models.signals.post_save, sender=settings.AUTH_USER_MODEL)
def send_reset_password_email(sender, instance, created, **kwargs):

    if created:

        # First create a post request to pass to the view
        request = HttpRequest()
        request.method = 'POST'

        # add the absolute url to be be included in email
        if settings.DEBUG:
            request.META['HTTP_HOST'] = '127.0.0.1:8000'
        else:
            request.META['HTTP_HOST'] = 'www.mysite.com'

        # pass the post form data
        request.POST = {
            'email': instance.email,
            'csrfmiddlewaretoken': get_token(HttpRequest())
        }
        PasswordResetView.as_view()(request)  # email will be sent!
2021-01-20