【问题标题】:'WSGIRequest' object has no attribute 'user''WSGIRequest' 对象没有属性 'user'
【发布时间】:2014-10-26 18:04:03
【问题描述】:

我正在尝试在我的 django 项目中创建一个身份验证模块。但是当我打开我的网站 url 时出现此错误:'WSGIRequest' object has no attribute 'user'

我正在尝试查找有关此问题的信息,有人说问题出在 MIDDLEWARE_CLASSES 中,但我无法理解。

这是我的 MIDDLEWARE_CLASSES:

MIDDLEWARE_CLASSES = (
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.common.CommonMiddleware',
    #'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    'django.middleware.clickjacking.XFrameOptionsMiddleware',
)

我的项目/admin.py

from django.contrib import admin
from personal_area.models import UserProfile

admin.site.register(UserProfile)

我的项目/forms.py

from personal_area.models import UserProfile
from django.contrib.auth.models import User
from django import forms


class UserForm(forms.Model):
    password = forms.CharField(widget=forms.PasswordInput())

    class Meta:
        model = User
        fields = ('username', 'email', 'password')


class UserProfileForm(forms.ModelForm):
    class Meta:
        model = UserProfile
        fields = ('website', 'picture')

我的项目/models.py

from django.db import models
from django.contrib.auth.models import User


class UserProfile(models.Model):

    user = models.OneToOneField(User)

    website = models.URLField(blank=True)
    picture = models.ImageField(upload_to='profile_images', blank=True)

    def __unicode__(self):
        return self.user.username

我的项目/views.py

from django.shortcuts import render, render_to_response, HttpResponseRedirect, RequestContext
from django.contrib import auth

from personal_area.forms import UserForm, UserProfileForm


def register(request):

    context = RequestContext(request)
    registered = False

    if request.method == 'Post':
        user_form = UserForm(data = request.POST)
        profile_form = UserProfileForm(data = request.POST)

        if user_form.is_valid() and profile_form.is_valid():
            user = user_form.save()

            user.set_password(user.password)
            user.save()

            profile = profile_form.save(commit = False)
            profile.user = user

            if 'picture' in request.FILES:
                profile.picture = request.FILES['picture']

            profile.save()
            registered = True

        else:
            print(user_form.errors, profile_form.errors)

    else:
        user_form = UserForm()
        profile_form = UserProfileForm()

    return render_to_response('personal_area/register.html', {'user_form': user_form, 'profile_form': profile_form,
                                                              'registered': registered}, context)

myproject/register.html

{% extends "home/base.html" %}

 {% block auth %}
        <h1>Register with Rango</h1>

        {% if registered %}
        Rango says: <strong>thank you for registering!</strong>
        <a href="/personal_area/">Return to the homepage.</a><br />
        {% else %}
        Rango says: <strong>register here!</strong><br />

        <form id="user_form" method="post" action="/personal_area/register/"
                enctype="multipart/form-data">

            {% csrf_token %}

            {{ user_form.as_p }}
            {{ profile_form.as_p }}

            <input type="submit" name="submit" value="Register" />
        </form>
        {% endif %}
{% endblock %}

这是我的模块的教程:

http://www.tangowithdjango.com/book/chapters/login.html#linking-together

【问题讨论】:

    标签: django django-middleware


    【解决方案1】:

    您的中间件排序错误。请仔细阅读this part。 顺序应该是:

    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
    

    【讨论】:

      【解决方案2】:

      只需在 MIDDLEWARE 之后删除 CLASSES,并注释掉 SessionAuthenticationMiddleware:

      MIDDLEWARE = (
          'django.contrib.sessions.middleware.SessionMiddleware',
          'django.middleware.common.CommonMiddleware',
          'django.middleware.csrf.CsrfViewMiddleware',
          'django.contrib.auth.middleware.AuthenticationMiddleware',
          #'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
          'django.contrib.messages.middleware.MessageMiddleware',
          'django.middleware.clickjacking.XFrameOptionsMiddleware',
      )
      

      【讨论】:

      • 这在从 Django 1.11 升级到 Django 2.0 后帮助了我
      猜你喜欢
      • 2016-10-23
      • 1970-01-01
      • 2019-10-20
      • 2016-07-30
      • 2020-02-09
      • 1970-01-01
      • 1970-01-01
      • 2015-04-21
      • 2017-02-02
      相关资源
      最近更新 更多