' WSGIRequest'对象没有属性'用户'

时间:2014-10-26 18:04:03

标签: django django-middleware

我正在尝试在我的django项目中创建一个auth模块。但是,当我打开我的网站网址时,我有一个错误:' WSGIRequest'对象没有属性'用户'

我试图找到有关此问题的信息,有人说问题出在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',
)

的myproject / admin.py

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

admin.site.register(UserProfile)

的myproject / 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')

的myproject / 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

的myproject / 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

2 个答案:

答案 0 :(得分:10)

您的中间件订购错误。请仔细阅读this part。 订单应该是:

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

答案 1 :(得分: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',
)