Django: HttpResponseRedirect не работает
Я новичок в Python / Django и программировании в целом. Мне нужна помощь с HttpResponseRedirect, поскольку он не работает в моем представлении входа в систему. Он работает из моего основного файла Views, но не так, как я хочу.
Вместо перенаправления на нужную страницу ('/'), я вижу это только на той же странице:
Content-Type: text / html; charset = utf-8 Расположение: /
Пользователь фактически входит в систему, но остается на той же странице. Так что, если я зайду на нужную страницу вручную, я увижу, что я вошел в систему.
Вот соответствующие фрагменты кода. Я использую свои собственные взгляды везде. Я хотел бы так для практики и лучшего понимания.
Urls.py
from django.conf.urls import patterns, include, url
from django.conf.urls.static import static
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.contrib import admin
from backend import settings
admin.autodiscover()
urlpatterns = patterns('',
url(r'^login/', 'backend.views.login', name = 'login'),
url(r'^logout/', 'backend.views.logout', name = 'logout'),
url(r'^Views.py
from dashboard.dashviews import left, right, topright
from authentication.authviews import LoginView, LogoutView
from django.shortcuts import render
from django.http import HttpResponseRedirect
from django.contrib.auth.decorators import login_required
@login_required(login_url='/login/')
def dash(request):
return render(request, 'dash_template.html',
{'left': left.dash_left(request),
'right': right.dash_right(),
'topright': topright.top_right(request)})
def login(request):
if not request.user.is_authenticated():
return render(request, 'login.html', {'login': LoginView.login_view(request)})
else:
return HttpResponseRedirect('/')
def logout(request):
return render(request, 'logout.html', {'logout': LogoutView.logout_view(request)}) and HttpResponseRedirect('/login/')
LoginView.py
from django.contrib import auth
from django.http import HttpResponseRedirect
def login_view(request):
username = request.POST.get('username', '')
password = request.POST.get('password', '')
user = auth.authenticate(username=username, password=password)
if user is not None and user.is_active:
# Correct password, and the user is marked "active"
auth.login(request, user)
# Redirect to dashboard
return HttpResponseRedirect('/')
else:
# Show a message
return 'Please enter your username and password below.'
login.html - простая форма
<center>
<p>{{ login }}</p>
{% if form.errors %}
<p class="error">Sorry, that's not a valid username or password</p>
{% endif %}
<form action="./" method="post">
<table border="0">
<tr>
<td>
<label for="username">Username:</label>
</td>
<td>
<input type="text" name="username" value="" id="username">
</td>
</tr>
<tr>
<td>
<label for="password">Password:</label>
</td>
<td>
<input type="password" name="password" value="" id="password">
</td>
</tr>
</table>
<input type="submit" value="login" />
<input type="hidden" name="next" value="/" />
{% csrf_token %}
</form>
</center>
Я следовал учебному пособию по Django по этому вопросу, и в соответствии с этим все должно работать просто отлично. Как вы можете видеть, я также пытался использовать скрытое поле «следующее» в моей форме, которое тоже не работает. Любая помощь будет оценена. Интересно, что мне здесь не хватает. Спасибо!
, 'backend.views.dash', name = 'dash'),
url(r'^admin/', include(admin.site.urls)),
) + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
urlpatterns += staticfiles_urlpatterns()
Views.py
from dashboard.dashviews import left, right, topright
from authentication.authviews import LoginView, LogoutView
from django.shortcuts import render
from django.http import HttpResponseRedirect
from django.contrib.auth.decorators import login_required
@login_required(login_url='/login/')
def dash(request):
return render(request, 'dash_template.html',
{'left': left.dash_left(request),
'right': right.dash_right(),
'topright': topright.top_right(request)})
def login(request):
if not request.user.is_authenticated():
return render(request, 'login.html', {'login': LoginView.login_view(request)})
else:
return HttpResponseRedirect('/')
def logout(request):
return render(request, 'logout.html', {'logout': LogoutView.logout_view(request)}) and HttpResponseRedirect('/login/')
LoginView.py
from django.contrib import auth
from django.http import HttpResponseRedirect
def login_view(request):
username = request.POST.get('username', '')
password = request.POST.get('password', '')
user = auth.authenticate(username=username, password=password)
if user is not None and user.is_active:
# Correct password, and the user is marked "active"
auth.login(request, user)
# Redirect to dashboard
return HttpResponseRedirect('/')
else:
# Show a message
return 'Please enter your username and password below.'
login.html - простая форма
<center>
<p>{{ login }}</p>
{% if form.errors %}
<p class="error">Sorry, that's not a valid username or password</p>
{% endif %}
<form action="./" method="post">
<table border="0">
<tr>
<td>
<label for="username">Username:</label>
</td>
<td>
<input type="text" name="username" value="" id="username">
</td>
</tr>
<tr>
<td>
<label for="password">Password:</label>
</td>
<td>
<input type="password" name="password" value="" id="password">
</td>
</tr>
</table>
<input type="submit" value="login" />
<input type="hidden" name="next" value="/" />
{% csrf_token %}
</form>
</center>
Я следовал учебному пособию по Django по этому вопросу, и в соответствии с этим все должно работать просто отлично. Как вы можете видеть, я также пытался использовать скрытое поле «следующее» в моей форме, которое тоже не работает. Любая помощь будет оценена. Интересно, что мне здесь не хватает. Спасибо!