Я использую django 1.6 и django-registration 1.0.Почему django 1.6 устанавливает «форму» в «none» на вкладке contrib.auth.views.password_reset_confirm?
мне пришлось латать URLs на Джанго регистрации, поскольку они не выпустили обновление от 19 февраля 2014 г.
Все URL-адрес сброса пароля/просмотров проработали password_reset_confirm кроме.
На моем главном файле urls.py у меня есть это:
url(r'^accounts/', include('registration.backends.simple.urls')),
О регистрации/Backend Серверах/Simple/urls.py У меня есть это:
from django.conf.urls import include
from django.conf.urls import patterns
from django.conf.urls import url
from django.views.generic.base import TemplateView
from registration.backends.simple.views import RegistrationView
urlpatterns = patterns('',
url(r'^register/$',
RegistrationView.as_view(),
name='registration_register'),
url(r'^register/closed/$',
TemplateView.as_view(template_name='registration/registration_closed.html'),
name='registration_disallowed'),
(r'', include('registration.auth_urls')),
)
from django.contrib.auth import views as auth_views
# THIS IS A PATCH added by me !!!
urlpatterns = patterns('',
# override the default urls
url(r'^password/change/$',
auth_views.password_change,
name='password_change'),
url(r'^password/change/done/$',
auth_views.password_change_done,
name='password_change_done'),
url(r'^password/reset/$',
auth_views.password_reset,
name='password_reset'),
url(r'^password/reset/done/$',
auth_views.password_reset_done,
name='password_reset_done'),
url(r'^password/reset/complete/$',
auth_views.password_reset_complete,
name='password_reset_complete'),
url(r'^password/reset/confirm/(?P<uidb64>[0-9A-Za-z]+)-(?P<token>.+)/$',
auth_views.password_reset_confirm,
name='password_reset_confirm'),
# and now add the registration urls
url(r'', include('registration.backends.default.urls')),
)
Django1.6 Джанго/вно/авториз/views.py имеет функцию password_reset_confirm:
# Doesn't need csrf_protect since no-one can guess the URL
@sensitive_post_parameters()
@never_cache
def password_reset_confirm(request, uidb64=None, token=None,
template_name='registration/password_reset_confirm.html',
token_generator=default_token_generator,
set_password_form=SetPasswordForm,
post_reset_redirect=None,
current_app=None, extra_context=None):
"""
View that checks the hash in a password reset link and presents a
form for entering a new password.
"""
UserModel = get_user_model()
assert uidb64 is not None and token is not None # checked by URLconf
if post_reset_redirect is None:
post_reset_redirect = reverse('password_reset_complete')
else:
post_reset_redirect = resolve_url(post_reset_redirect)
try:
uid = urlsafe_base64_decode(uidb64)
user = UserModel._default_manager.get(pk=uid)
except (TypeError, ValueError, OverflowError, UserModel.DoesNotExist):
user = None
if user is not None and token_generator.check_token(user, token):
validlink = True
if request.method == 'POST':
form = set_password_form(user, request.POST)
if form.is_valid():
form.save()
return HttpResponseRedirect(post_reset_redirect)
else:
form = set_password_form(None)
else:
validlink = False
form = None
context = {
'form': form,
'validlink': validlink,
}
if extra_context is not None:
context.update(extra_context)
return TemplateResponse(request, template_name, context,
current_app=current_app)
Так как token_generator.check_token (пользователя, маркер) является возврат False или пользователя == Нет.
Самая большая боль в том, что это происходит только (что мне кажется) случайным образом. Поэтому отладка - это боль. Иногда он работает ({{ form }}
отображает входы), и часто он терпит неудачу ({{ form }}
оказывает «Нет» вместо ввода разметки)
Любая помощь будет очень признательна.
Можете ли вы скопировать свой точный код? Ваше форматирование немного отключено. – karthikr
@karthikr Я только что обновил вопрос с помощью кода из моего собственного файла urls.py, файла urls.py django-registration и файла django 1.6 contrib.auth.views.py. – teewuane
Убедитесь, что 'urlsafe_base64_decode (uidb64)' возвращает действительный uid. Затем перед тем, как «если пользователь не является None», выполните «печать пользователя», если он показывает допустимое значение. – karthikr