Я пытаюсь создать приложение для сброса пароля пользователя по электронной почте. Я использую главу 3 книги «Django by Example», а также руководствовался этим сайтом: https://simpleisbetterthancomplex.com/tutorial/2016/09/19/how-to-create-password-reset-view.html
Settings.py содержит следующую строку:
EMAIL_BACKEND = 'django.core.mail.backends.console.EmailBackend'
вместе с необходимыми настройками электронной почты.
Я перехожу к представлению password_reset
, ввожу фиктивную почту, нажимаю кнопку «Отправить», что, наконец, приводит меня к представлению password_reset_done
. Ниже представлен вывод консоли:
C:\PythonProjects\by-example-bookmarks>python manage.py runserver
Performing system checks...
System check identified no issues (0 silenced).
May 01, 2018 - 21:13:39
Django version 2.0.4, using settings 'bookmarks.settings'
Starting development server at http://127.0.0.1:8000/
Quit the server with CTRL-BREAK.
[01/May/2018 21:13:51] "GET /account/login/ HTTP/1.1" 200 1090
[01/May/2018 21:13:57] "GET /account/password_reset/ HTTP/1.1" 200 830
[01/May/2018 21:14:04] "POST /account/password_reset/ HTTP/1.1" 302 0
[01/May/2018 21:14:05] "GET /account/password_reset/done/ HTTP/1.1" 200 602
После вывода "POST"
я ожидал увидеть дамп электронного письма в ответ на настройку .console.EmailBackend
, но ничего не получил.
В чем может быть причина невозможности имитации отправки электронной почты?
Среда:
Windows 7, django 2.0, на консоли CMD, под оболочкой pipenv
Редактировать 1 Та же проблема на другой машине.
Редактировать 2
Переход на .smtp
ничего не меняет, никаких ошибок.
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
Редактировать 3 Пробовал чужие работы, вот такую: https://github.com/ruddra/django-reset-password/tree/master
По-прежнему не повезло.
Редактировать 4 Очередная «чужая работа». По-прежнему не повезло. https://github.com/wsvincent/django-auth-tutorial
Это когда-нибудь работает?
Изменить 5: views.py
from django.http import HttpResponse
from django.shortcuts import render
from django.contrib.auth import authenticate, login
from .forms import LoginForm
from django.contrib.auth.decorators import login_required
def user_login(request):
if request.method == 'POST':
form = LoginForm(request.POST)
if form.is_valid():
cd = form.cleaned_data
user = authenticate( username=cd['username'],
password=cd['password'])
if user is not None:
if user.is_active:
login(request, user)
return HttpResponse('Authenticated '\
'successfully')
else:
return HttpResponse('Disabled account')
else:
return HttpResponse('Invalid login')
else:
form = LoginForm()
return render(request, 'account/login.html', {'form': form})
@login_required
def dashboard(request):
return render(request,
'account/dashboard.html',
{'section': 'dashboard'})
urls.py
from django.conf.urls import url, include
from . import views
import django.contrib.auth.views
# i think the following does not serve any purpose anymore
from django.contrib.auth import views as auth_views
urlpatterns = [
# previous login view
# url(r'^login/$', views.user_login, name='login'),
# login / logout urls
url(r'^login/$',
django.contrib.auth.views.login,
name='login'),
url(r'^logout/$',
django.contrib.auth.views.logout,
name='logout'),
url(r'^logout-then-login/$',
django.contrib.auth.views.logout_then_login,
name='logout_then_login'),
url(r'^$', views.dashboard, name='dashboard'),
url(r'^password-change/$',
django.contrib.auth.views.password_change,
name='password_change'),
url(r'^password-change/done/$',
django.contrib.auth.views.password_change_done,
name='password_change_done'),
# restore password urls
url('^', include('django.contrib.auth.urls')),
]
редактировать 6 Мое репозиторий на github здесь, на случай, если кому-то интересно: https://github.com/jeffplata/by-example-account
@BurhanKhalid, views.py включен в edit. На самом деле там особо не на что смотреть. Возможно, вы захотите взглянуть на urls.py
.
Какую версию django вы используете?
@ Бурхан, django 2.0
Просто любопытно - вы добавили пользователя, сделали его активным и дали ему адрес электронной почты, верно? Посмотрите здесь, так как ваш urls.py
не подходит.
@Burhan да, у меня есть активный пользователь с emaiil
Теперь это работает. Как было предложено @Burhan Khalid, очень тщательно удостоверился, что есть пользователь с действующим адресом электронной почты. В частности, электронное письмо, которое я набираю в режиме сброса, находится в модели / таблице «Пользователи».
Спасибо, чувак, последние 2 недели я делал то же самое неправильно. Спасибо за ответ.
Можете ли вы опубликовать представление, которое используете?