2013-12-18 3 views
6

Я хочу использовать userena для моего сайта django. Сначала работаю с userena.ошибка базы данных, нет такой таблицы: auth_user в django

я создал приложение именно «счета» для пользователя знака и петь, где мой models.py является

from django.db import models 
from django.contrib.auth.models import User 
from django.utils.translation import ugettext as _ 
from userena.models import UserenaBaseProfile 

class MyProfile(UserenaBaseProfile): 
user = models.OneToOneField(User, 
          unique=True, 
          verbose_name=_('user'), 
          related_name='my_profile') 
favourite_snack = models.CharField(_('favourite snack'), 
            max_length=5) 

и мой settings.py является

# Django settings for photostock project. 

DEBUG = True 
TEMPLATE_DEBUG = DEBUG 

ADMINS = (
# ('Your Name', '[email protected]'), 
) 

MANAGERS = ADMINS 
EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend' 
EMAIL_USE_TLS = True 
EMAIL_HOST = 'smtp.gmail.com' 
EMAIL_PORT = 587 
EMAIL_HOST_USER = '[email protected]' 
EMAIL_HOST_PASSWORD = '[email protected]#' 

DATABASES = { 
'default': { 
    'ENGINE': 'django.db.backends.sqlite3', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'. 
    'NAME': 'photo',      # Or path to database file if using sqlite3. 
    # The following settings are not used with sqlite3: 
    'USER': '', 
    'PASSWORD': '', 
    'HOST': '',      # Empty for localhost through domain sockets or '127.0.0.1' for localhost through TCP. 
    'PORT': '',      # Set to empty string for default. 
} 
} 
    AUTHENTICATION_BACKENDS = (
        'userena.backends.UserenaAuthenticationBackend', 
        'guardian.backends.ObjectPermissionBackend', 
        'django.contrib.auth.backends.ModelBackend', 
      ) 
    #AUTH_USER_MODEL = "login.PropaUser" 

    # Hosts/domain names that are valid for this site; required if DEBUG is False 
    # See https://docs.djangoproject.com/en/1.5/ref/settings/#allowed-hosts 
    ALLOWED_HOSTS = [] 

    # Local time zone for this installation. Choices can be found here: 
    # http://en.wikipedia.org/wiki/List_of_tz_zones_by_name 
    # although not all choices may be available on all operating systems. 
    # In a Windows environment this must be set to your system time zone. 
    TIME_ZONE = 'America/Chicago' 

    # Language code for this installation. All choices can be found here: 
    # http://www.i18nguy.com/unicode/language-identifiers.html 
    LANGUAGE_CODE = 'en-us' 

    SITE_ID = 1 

    # If you set this to False, Django will make some optimizations so as not 
    # to load the internationalization machinery. 
    USE_I18N = True 

    # If you set this to False, Django will not format dates, numbers and 
    # calendars according to the current locale. 
    USE_L10N = True 

    # If you set this to False, Django will not use timezone-aware datetimes. 
    USE_TZ = True 

    # Absolute filesystem path to the directory that will hold user-uploaded files. 
    # Example: "/var/www/example.com/media/" 
    MEDIA_ROOT = '' 

# URL that handles the media served from MEDIA_ROOT. Make sure to use a 
# trailing slash. 
# Examples: "http://example.com/media/", "http://media.example.com/" 
MEDIA_URL = '' 

# Absolute path to the directory static files should be collected to. 
# Don't put anything in this directory yourself; store your static files 
# in apps' "static/" subdirectories and in STATICFILES_DIRS. 
# Example: "/var/www/example.com/static/" 
STATIC_ROOT = '' 

# URL prefix for static files. 
# Example: "http://example.com/static/", "http://static.example.com/" 
STATIC_URL = '/static/' 

# Additional locations of static files 
STATICFILES_DIRS = (
# Put strings here, like "/home/html/static" or "C:/www/django/static". 
# Always use forward slashes, even on Windows. 
# Don't forget to use absolute paths, not relative paths. 
) 

# List of finder classes that know how to find static files in 
# various locations. 
STATICFILES_FINDERS = (
     'django.contrib.staticfiles.finders.FileSystemFinder', 
     'django.contrib.staticfiles.finders.AppDirectoriesFinder', 
#   'django.contrib.staticfiles.finders.DefaultStorageFinder', 
) 

# Make this unique, and don't share it with anybody. 
SECRET_KEY = 'tr!)ra#+%miw(qo^ot)[email protected]+$2+4o9io=7p6w3hd=i$3m2!tkr' 

# List of callables that know how to import templates from various sources. 
TEMPLATE_LOADERS = (
     'django.template.loaders.filesystem.Loader', 
     'django.template.loaders.app_directories.Loader', 
#   'django.template.loaders.eggs.Loader', 
) 

MIDDLEWARE_CLASSES = (
     'django.middleware.common.CommonMiddleware', 
     'django.contrib.sessions.middleware.SessionMiddleware', 
     'django.middleware.csrf.CsrfViewMiddleware', 
     'django.contrib.auth.middleware.AuthenticationMiddleware', 
     'django.contrib.messages.middleware.MessageMiddleware', 
     # Uncomment the next line for simple clickjacking protection: 
     # 'django.middleware.clickjacking.XFrameOptionsMiddleware', 
) 

ROOT_URLCONF = 'photostock.urls' 

# Python dotted path to the WSGI application used by Django's runserver. 
WSGI_APPLICATION = 'photostock.wsgi.application' 

TEMPLATE_DIRS = (
     # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates". 
     # Always use forward slashes, even on Windows. 
     # Don't forget to use absolute paths, not relative paths. 
) 

INSTALLED_APPS = (
     'django.contrib.auth', 
     'django.contrib.contenttypes', 
     'django.contrib.sessions', 
     'django.contrib.sites', 
     'django.contrib.messages', 
     'django.contrib.staticfiles', 
     # Uncomment the next line to enable the admin: 
     # 'django.contrib.admin', 
     # Uncomment the next line to enable admin documentation: 
     # 'django.contrib.admindocs', 
     'userena', 
     'guardian', 
     'easy_thumbnails', 
     'accounts', 
) 
    ANONYMOUS_USER_ID = -1 
    AUTH_PROFILE_MODULE = 'accounts.MyProfile' 

LOGIN_REDIRECT_URL = '/accounts/%(username)s/' 
LOGIN_URL = '/accounts/signin/' 
LOGOUT_URL = '/accounts/signout/' 

SESSION_SERIALIZER = 'django.contrib.sessions.serializers.JSONSerializer' 

# A sample logging configuration. The only tangible logging 
# performed by this configuration is to send an email to 
# the site admins on every HTTP 500 error when DEBUG=False. 
# See http://docs.djangoproject.com/en/dev/topics/logging for 
# more details on how to customize your logging configuration. 
LOGGING = { 
    'version': 1, 
    'disable_existing_loggers': False, 
    'filters': { 
     'require_debug_false': { 
      '()': 'django.utils.log.RequireDebugFalse' 
      } 
    }, 
'handlers': { 
    'mail_admins': { 
     'level': 'ERROR', 
     'filters': ['require_debug_false'], 
     'class': 'django.utils.log.AdminEmailHandler' 
    } 
}, 
'loggers': { 
    'django.request': { 
     'handlers': ['mail_admins'], 
     'level': 'ERROR', 
     'propagate': True, 
    }, 
} 
} 

я уже показал петь на странице и подписывать страницу на моем сайте, используя userena.Validation работает хорошо, но пока я пытаюсь зарегистрироваться, заполнив все необходимое поле и нажав кнопку отправки, появится ошибка, то есть

DatabaseError at /accounts/signin/ 

no such table: auth_user 

Request Method: POST 
Request URL: http://localhost:8000/accounts/signin/ 
Django Version: 1.5.5 
Exception Type: DatabaseError 
Exception Value: no such table: auth_user 

, упоминание, я не вносил никаких изменений в свои проекты models.py file.though, это ошибка базы данных, имеет ли она какое-либо соединение с моими проектами models.py ?? Есть ли что-нибудь, чтобы сделать больше?

Я должен упомянуть, что я действительно amature, который работает с userena.so, если у вас есть какие-либо решения или подсказка для решения этой проблемы, пожалуйста, помогите мне.

+3

создана ли таблица AUTH_USER когда вы SyncDB? –

ответ

1

Как указывает Асвин Муругеш, вы должны проверить свою базу данных и убедиться, что таблицы созданы. Если вы запустили ./manage.py syncdb и по-прежнему получаете эту ошибку, я бы рекомендовал установить SQLite-браузер, такой как SQLiteman (http://sqliteman.yarpen.cz/sudo apt-get install sqliteman) и открыть ваш файл SQLite и проверить базу данных. Это скажет вам, работает ли база данных.

Часто при использовании SQLite вы можете сделать резервную копию своей базы данных, а затем начать с нуля и получить все свежие таблицы. Разрабатывая ocally, управляя однофайловой базой данных, такой как SQLite, менее сложно уничтожить базу данных и начать ее, если вы находитесь в привязке.

Вы всегда можете создать новый virtualenv и запустить новый проект Django (если вы действительно застряли) и заставить Userena работать так же.

1

Добавить в settings.py:

AUTH_PROFILE_MODULE = 'accounts.MyProfile' 
0

Перед созданием собственной модели пользователя, первая миграция должна быть выполнена. Затем установите приложение вашей модели пользователя и добавить AUTH_USER_MODEL

https://stackoverflow.com/a/41628647/6472582

Смежные вопросы