Próbuję zapisać identyfikator użytkownika w sesji przy użyciu django.contrib.auth.login. Ale nie działa niezgodnie z oczekiwaniami.Django "login() zajmuje dokładnie 1 argument (2 dane)" error
Dostaję błędu login() wykonuje dokładnie 1 argument (2 podany)
login (użytkownik) Dostaję AttributeError w/login/user”obiektu nie ma atrybutu 'metoda'
Używam nieznacznie modifyed przykładowy formularz http://docs.djangoproject.com/en/dev/topics/auth/:
from django.shortcuts import render_to_response
from django.contrib.auth import authenticate, login
def login(request):
msg = []
if request.method == 'POST':
username = request.POST['u']
password = request.POST['p']
user = authenticate(username=username, password=password)
if user is not None:
if user.is_active:
login(request, user)
msg.append("login successful")
else:
msg.append("disabled account")
else:
msg.append("invalid login")
return render_to_response('login.html', {'errors': msg})
nic szczególnego login.html:
<html>
<head>
<title></title>
</head>
<body>
<form action="/login/" method="post">
Login: <input type="text" name="u">
<br/>
Password: <input type="password" name="p">
<input type="submit" value="Login">
</form>
{% if errors %}
<ul>
{% for error in errors %}
<li>{{ error }}</li>
{% endfor %}
</ul>
{% endif %}
</body>
</html>
Czy ktoś ma pomysł, jak zrobić logowanie() działa.
będzie działać, jeśli zmienisz nazwę widoku – Evgeny
Tylko pytanie i odpowiedź, której szukałem. Jeden z kilku błędów, które popełniłem, próbując uruchomić logowanie w django, używając Contexts vs RequestContexts i pomijając csrf_tokens. – chucksmash
tutaj możesz znaleźć samouczek o użytkownikach Django http://lowcoupling.com/post/71289666862/django-the-user-tutorial Istnieje również projekt GitHub, który możesz sklonować i sprawdzić – lowcoupling