无法使用正确的用户名和密码登录到 Django 管理员
Posted
技术标签:
【中文标题】无法使用正确的用户名和密码登录到 Django 管理员【英文标题】:Can't login to Django admin using correct username and password 【发布时间】:2014-02-13 14:58:11 【问题描述】:我使用ngnix
、gunicorn
和Postgresql
数据库在DigitalOcean 上部署了一个Django 应用程序。一切正常,当我运行python manage.py syncdb
时,我能够创建一个很好地填充我的数据库的用户。
我遇到的问题是,当我尝试登录 Django 管理界面时,系统提示我使用了错误的用户名和/或密码。我很确定凭据是正确的,因为我多次尝试设置数据库。
任何想法为什么 Django 认为我输入了错误的用户信息?
谢谢!
SETTINGS.py 看起来像
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
import os
BASE_DIR = os.path.dirname(os.path.dirname(__file__))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.6/howto/deployment/checklist/
# SECURITY WARNING: keep the secret key used in production secret!
SECRET_KEY = 'XXXXXXXXXXXXXXX'
# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True
TEMPLATE_DEBUG = True
ALLOWED_HOSTS = []
# Application definition
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
'django.contrib.admin',
)
MIDDLEWARE_CLASSES = (
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
)
ROOT_URLCONF = 'qvido.urls'
WSGI_APPLICATION = 'qvido.wsgi.application'
# Database
# https://docs.djangoproject.com/en/1.6/ref/settings/#databases
DATABASES =
'default':
'ENGINE': 'django.db.backends.postgresql_psycopg2',
'NAME': 'mydbname',
'USER': 'user',
'PASSWORD': 'pass!',
'HOST': 'localhost',
'ROOT': '',
# Internationalization
# https://docs.djangoproject.com/en/1.6/topics/i18n/
LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True
# Static files (CSS, javascript, Images)
# https://docs.djangoproject.com/en/1.6/howto/static-files/
STATIC_ROOT = '/webapps/django-env/static/'
STATIC_URL = '/static/'
WSGI.py看起来像
import os
os.environ.setdefault("DJANGO_SETTINGS_MODULE", "qvido.settings")
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()
编辑
好的,我也尝试过python manage.py dbshell
和select * from auth_user;
我看到了我创建的用户,但仍然无法使用它登录。这么奇怪。
【问题讨论】:
你能不能再试试“python manage.py createsuperuser”来创建一个超级用户。然后尝试使用新的用户名和密码登录。 尝试使用新的超级用户登录时仍然收到相同的提示。记录在数据库中创建。 您是使用默认的 django 身份验证还是修改了 django 身份验证? 你能直接连接到数据库并确保你的用户是真实创建的吗? @Ismailp 因为我们共享相同的名称 :D,我相信您有多个代码实例,并且您通过 wsgi 运行错误一个 【参考方案1】:我为迟到的答案道歉,但我相信这可能对某人有用。
我遇到了同样的问题。在阅读了原始问题的所有 cmets 后,我能够弄清楚发生了什么。
在开发过程中,我已将数据库从旧的测试数据库切换到新的数据库,其中包含所有必需的表,而不仅仅是更改现有的数据库。我只更改了settings.py
文件以更新新数据库的位置,并没有触及wsgi.py
文件。迁移到新数据库并从项目中删除旧文件后,我的管理员用户在新数据库中不存在。
基于 @Torsten Engelbrecht 和 OP 的 cmets,我需要做的就是运行 @Alen thomas 建议的命令以使其再次发挥作用:
python manage.py createsuperuser
此时我能够设置我之前使用的相同管理员帐户,因为它不再存在。现在一切正常。这可能看起来有点傻,但检查一下是值得的
【讨论】:
【参考方案2】:所以,我找到了为什么会发生这种情况的答案,而且@scriptmonster 确实是正确的。
当我在我的 virtual-env 中安装 Django、Gunicorn 等时,我使用了 sudo pip install,它将这些安装在我的 virtaul-env 之外。
我运行了sudo chown -R myuser:myuser /webapps/myenv
,然后又运行了pip install django
和pip install gunicorn
,一切正常。
【讨论】:
以上是关于无法使用正确的用户名和密码登录到 Django 管理员的主要内容,如果未能解决你的问题,请参考以下文章
无法使用用户名/密码登录令牌端点:drf 令牌身份验证和自定义用户模型,Django
我无法使用有效的用户名和密码登录 Django 管理页面,它返回 % csrf_token % 禁止的 404 错误消息