抱歉,如果已经有一个实质性的答案,我已经搜索了很长时间,找不到任何有用的答案。
我有一个django项目,具有不同级别的帐户访问权限。我有一组“经理”,我想允许他们管理用户帐户。
我希望经理能够为用户创建用户帐户对象。但是,我不希望他们不得不创建密码并将其发送给用户(出于明显的原因)。这样,管理员可以模拟用户代表他们完成工作,并且用户可以维护密码控制和数据所有权。
想法是由管理员创建帐户,并在创建帐户时向用户发送密码重设表单(与django的即用型身份验证相同),该表单将允许他们设置密码。
我的代码类似于以下内容(省略了非命令性的内容)
from django.contrib.auth.models import User
from django.contrib.auth.forms import PasswordResetForm
@manager_required
def manager_add_users(request):
add_user_form = manager_add_user_form(request.POST)
new_user_name = add_user_form.cleaned_data['user_name']
new_user_email = add_user_form.cleaned_data['user_email']
new_user = User.objects.create_user(
username = new_user_name,
email = new_user_email,
)
new_user.save()
set_password_form = PasswordResetForm({'email': new_user.email })
if set_password_form.is_valid():
print 'Reset Form Is Valid'
set_password_form.save(
request= request,
use_https=True,
from_email="[email protected]",
email_template_name='registration/password_reset_email.html')
该帐户可以正确创建,并且一切运行都没有错误。问题是,尽管该表单有效(重置表单是有效的语句打印),但它实际上并未发送重置表单。没有表格错误。
但是,在测试中,当我使用系统中已经存在的地址初始化表单时,如下所示:
set_password_form = PasswordResetForm({'email':'[email protected]'})
密码重置表格发送无误。因此,它仅适用于系统中现有的用户电子邮件地址,但是尽管已经创建了用户并调用了.save()方法,但仍无法捕获该用户(用户在创建时被标记为“活动”,因此应该能够找到)
我有点茫然。我可以想到一些解决该问题的方法,但是这似乎是解决问题的最直接方法,而且我真的不完全确定为什么它不起作用。
是的,我能够发送消息。我正在使用django的后端邮件进行测试:
EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
看一下源代码,看起来Django忽略了该请求,因为密码为空。
django.utils.crypto.get_random_string()
在保存用户之前,请尝试设置一个临时密码(例如使用)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句