我有Django的自定义用户类,因为我需要使用电子邮件地址而不是用户名,不知道这是相关的问题,但我想补充一点,以防万一。我试图在成功登录后将用户重定向到他们的仪表板,但是,当我尝试通过URL调用重定向时,我似乎失去了通过request.user访问登录用户数据的能力。如何将页面从登录重定向到仪表板并在两个视图之间维护用户的会话数据?会话和身份验证系统的django文档似乎建议您可以在任何地方使用会话,并且如果为用户调用登录方法(存储在cookie中的会话的引用可能是?),那么数据将可用,但是当我尝试使在session.user
对象数据呼叫,没有数据存在,如果我想要做这样的事情,说你好request.user.first_name
,目前还没有这样的可调用的任何数据。Django的1.10:访问会话数据后重定向
urls.py
from django.conf.urls import url
from . import views
urlpatterns = [
url(r'^create$', views.user_create),
url(r'^login', views.user_login),
url(r'^dashboard', views.display_dashboard)
]
views.py
from django.shortcuts import render, HttpResponse, redirect
from forms import RegisterForm, LoginForm
from django.contrib.auth import get_user_model, authenticate, login
# Create your views here.
def user_create(request):
if request.method == "POST":
get_user_model().object.create_user(request.POST['email_address'], request.POST['password'],
request.POST['first_name'], request.POST['last_name'],
request.POST['language'])
return render(request, 'UserHandler/user_create.html', {'form': RegisterForm})
def user_login(request):
if request.method == "POST":
user = authenticate(email_address=request.POST['email_address'], password=request.POST['password'])
if user is not None:
login(request, user)
return redirect('user/dashboard')
else:
return HttpResponse("<h3>Login Failure</h3>")
else:
return render(request, 'UserHandler/login.html', {'form': LoginForm})
def display_dashboard(request):
if request.user.is_authenticated():
return render(request, 'UserHandler/auth_dashboard.html', {'user_first_name': request.user.first_name})
else:
return render(request, 'UserHandler/login.html', {'form': LoginForm})
auth_dashboard.html
{% extends 'UserHandler/base_site.html' %}
{% block content %}
Hi {{ user_first_name }} here is your dashboard!
{% endblock %}
backends.py
from django.contrib.auth.hashers import check_password
from models import AuthLookup
class AuthLookupBackend(object):
def authenticate(self, email_address=None, password=None):
user = AuthLookup.object.get(email_address=email_address)
if user is not None:
try:
if check_password(password, user.password):
return user
else:
return None
except user.DoesNotExist:
return None
def get_user(self, user_id):
try:
user = AuthLookup.objects.get(pk=user_id)
return user
except AuthLookup.DoesNotExist:
return None
自定义用户模型和models.py的usermanage部分
class AuthLookup(AbstractBaseUser, PermissionsMixin):
email_address = models.EmailField(unique=True)
first_name = models.CharField(max_length=100)
last_name = models.CharField(max_length=100)
# Remove the is_staff, is_superuser when done using the development database
is_staff = models.BooleanField(default=False)
is_superuser = models.BooleanField(default=False)
user_identifier = models.UUIDField(null=False, max_length=36, default=uuid.uuid4)
language = models.CharField(max_length=6, default='US_EN')
user_added = models.DateTimeField(default='1970-01-01 00:00:00')
object = AuthManager()
USERNAME_FIELD = 'email_address'
REQUIRED_FIELDS = ['first_name', 'last_name', 'language']
def get_short_name(self):
return self.email_address
class AuthManager(BaseUserManager):
def create_superuser(self, email_address, password, first_name, last_name, language):
email_address = self.normalize_email(email_address)
superuser = AuthLookup()
superuser.email_address = email_address
superuser.set_password(password)
superuser.first_name = first_name
superuser.last_name = last_name
superuser.language = language
superuser.is_superuser = True
superuser.is_staff = True
superuser.save(using=self._db)
return superuser
def create_user(self, email_address, password, first_name, last_name, language):
email_address = self.normalize_email(email_address)
user = AuthLookup()
user.email_address = email_address
user.set_password(password)
user.first_name = first_name
user.last_name = last_name
user.language = language
user.is_staff = False
user.is_superuser = False
user.save(using=self._db)
return user
当我使用此代码,登录后,我得到:
TRACEBACK
File "/home/dev/.local/lib/python2.7/site-packages/django/core/handlers/exception.py" in inner
39. response = get_response(request)
File "/home/dev/.local/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response
187. response = self.process_exception_by_middleware(e, request)
File "/home/dev/.local/lib/python2.7/site-packages/django/core/handlers/base.py" in _get_response
185. response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/home/dev/DjangoProjects/myProj/UserHandler/views.py" in display_dashboard
26. if request.user.is_authenticated():
File "/home/dev/.local/lib/python2.7/site-packages/django/utils/functional.py" in inner
234. self._setup()
File "/home/dev/.local/lib/python2.7/site-packages/django/utils/functional.py" in _setup
380. self._wrapped = self._setupfunc()
File "/home/dev/.local/lib/python2.7/site-packages/django/contrib/auth/middleware.py" in <lambda>
24. request.user = SimpleLazyObject(lambda: get_user(request))
File "/home/dev/.local/lib/python2.7/site-packages/django/contrib/auth/middleware.py" in get_user
12. request._cached_user = auth.get_user(request)
File "/home/dev/.local/lib/python2.7/site-packages/django/contrib/auth/__init__.py" in get_user
187. user = backend.get_user(user_id)
File "/home/dev/DjangoProjects/myProj/UserHandler/backends.py" in get_user
21. user = AuthLookup.objects.get(pk=user_id)
Exception Type: AttributeError at /user/dashboard
Exception Value: type object 'AuthLookup' has no attribute 'objects'
不过,我不叫重定向作为测试,而是做呼叫
if request.user.is_authenticated():
return HttpResponse(request.user.first_name)
在重定向的地方,if语句对True
和我得到显示已登录用户的名字页面
在此先感谢您的帮助。
请注明您'UserHandler/backends.py'和'AuthLookup'模型.. –