Я не могу войти на страницу администрирования django. Когда я ввожу действительное имя пользователя и пароль, он снова вызывает страницу входа в систему, без сообщений об ошибках
Этот вопрос находится в разделе django FAQ, но я перешел к ответам там и до сих пор не могу пройти мимо начального экрана входа.
Я использую django 1.4 на ubuntu 12.04 с apache2 и modwsgi.
Я подтвердил, что регистрирую администратор в файле admin.py
, после добавления INSTALLED_APPS
убедитесь, что syncdb.
Когда я ввожу неправильный пароль, я получаю сообщение об ошибке, поэтому мой администратор аутентифицируется, просто не переходя на страницу администратора.
Я попытался установить SESSION_COOKIE_DOMAIN
на IP-адрес устройства и None. (Подтверждено, что домен cookie отображается как IP-адрес устройства в хроме)
Также проверяется, что пользователь аутентифицируется через оболочку:
>>> from django.contrib.auth import authenticate
>>> u = authenticate(username="user", password="pass")
>>> u.is_staff
True
>>> u.is_superuser
True
>>> u.is_active
True
Попытка входа в систему с использованием IE8 и хром-канарейки приводит к тому же возврату на экран входа в систему.
Есть ли что-то еще, что мне не хватает????
settings.py
...
MIDDLEWARE_CLASSES = (
'django.middleware.gzip.GZipMiddleware',
'django.middleware.common.CommonMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'django.middleware.transaction.TransactionMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
)
AUTHENTICATION_BACKENDS = ('django.contrib.auth.backends.ModelBackend',)
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.admin',
'django.contrib.staticfiles',
'django.contrib.gis',
'myapp.main',
)
SESSION_EXPIRE_AT_BROWSER_CLOSE = True
SESSION_SAVE_EVERY_REQUEST = True
SESSION_COOKIE_AGE = 86400 # sec
SESSION_COOKIE_DOMAIN = None
SESSION_COOKIE_NAME = 'DSESSIONID'
SESSION_COOKIE_SECURE = False
urls.py
from django.conf.urls.defaults import * #@UnusedWildImport
from django.contrib.staticfiles.urls import staticfiles_urlpatterns
from django.contrib import admin
admin.autodiscover()
urlpatterns = patterns('',
(r'^bin/', include('myproject.main.urls')),
(r'^layer/r(?P<layer_id>\d+)/$', "myproject.layer.views.get_result_layer"),
(r'^layer/b(?P<layer_id>\d+)/$', "myproject.layer.views.get_baseline_layer"),
(r'^layer/c(?P<layer_id>\d+)/$', "myproject.layer.views.get_candidate_layer"),
(r'^layers/$', "myproject.layer.views.get_layer_definitions"),
(r'^js/mapui.js$', "myproject.layer.views.view_mapjs"),
(r'^tilestache/config/$', "myproject.layer.views.get_tilestache_cfg"),
(r'^admin/', include(admin.site.urls)),
(r'^sites/', include("myproject.sites.urls")),
(r'^$', "myproject.layer.views.view_map"),
)
urlpatterns += staticfiles_urlpatterns()
Версия Apache:
Apache/2.2.22 (Ubuntu) mod_wsgi/3.3 Python/2.7.3 configured
Apache apache2/sites-available/default:
<VirtualHost *:80>
ServerAdmin [email protected]
DocumentRoot /var/www/bin
LogLevel warn
WSGIDaemonProcess lbs processes=2 maximum-requests=500 threads=1
WSGIProcessGroup lbs
WSGIScriptAlias / /var/www/bin/apache/django.wsgi
Alias /static /var/www/lbs/static/
</VirtualHost>
<VirtualHost *:8080>
ServerAdmin [email protected]
DocumentRoot /var/www/bin
LogLevel warn
WSGIDaemonProcess tilestache processes=2 maximum-requests=500 threads=1
WSGIProcessGroup tilestache
WSGIScriptAlias / /var/www/bin/tileserver/tilestache.wsgi
</VirtualHost>
UPDATE
Страница администрирования выполняется при использовании сервера разработки через runserver
, поэтому кажется, что проблема wsgi/apache. Пока еще не понял.
Решение
Проблема заключалась в том, что у меня был установлен файл настроек SESSION_ENGINE
, установленный на 'django.contrib.sessions.backends.cache'
, без правильной настройки CACHE_BACKEND
.
Я изменил SESSION_ENGINE на 'django.contrib.sessions.backends.db'
, который разрешил проблему.