Ошибка сервера Django Whitenoise 500 в режиме без отладки - PullRequest
0 голосов
/ 20 декабря 2018

Я использую django на своей локальной машине.Чтобы обслуживать статические файлы, я использовал WhiteNoise вместе с ним.При DEBUG = True все статические файлы корректно обслуживаются.Но когда я изменил DEBUG = False и установил ALLOWED_HOSTS = ['*'], я получаю 500 ошибок сервера.Однако администратор сайта загружается без каких-либо ошибок.Также, когда я комментирую STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage', я не получаю ошибку 500.

Я следовал документации, приведенной в http://whitenoise.evans.io/en/stable/django.html, для подключения белого цвета.Я не внес никаких изменений в файл wsgi.py.Я запустил python manage.py collecststatic, и он запустился без ошибок.

settings.py дано ниже:

import os
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

SECRET_KEY = 'fdft&b(xb*!qq3ghjkjhg6789ih8ik!w10$0uscxcpqpmz'
DEBUG = False

ALLOWED_HOSTS = ['*']

INSTALLED_APPS = [
'whitenoise.runserver_nostatic', #Disable Djangos static file server during DEVELOPMENT
'gep_app.apps.GepAppConfig',
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
]

MIDDLEWARE = [
'django.middleware.security.SecurityMiddleware',
'whitenoise.middleware.WhiteNoiseMiddleware',
'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 = 'gep_project.urls'

TEMPLATES = [
{
    'BACKEND': 'django.template.backends.django.DjangoTemplates',
    'DIRS': [],
    'APP_DIRS': True,
    'OPTIONS': {
        'context_processors': [
            'django.template.context_processors.debug',
            'django.template.context_processors.request',
            'django.contrib.auth.context_processors.auth',
            'django.contrib.messages.context_processors.messages',
        ],
    },
},
]

WSGI_APPLICATION = 'gep_project.wsgi.application'


DATABASES = {
'default': {
    'ENGINE': 'django.db.backends.postgresql_psycopg2',
    'NAME': '*************',
    'USER': '*****',
    'PASSWORD': '********',
    'HOST': '*****',
    'PORT': '5432',
}
}

 # User model
 AUTH_USER_MODEL = 'gep_app.User'

 # Login URL
 LOGIN_URL = 'login'

 # Login redirect
 LOGIN_REDIRECT_URL = 'home'

 # Logout redirect
 LOGOUT_REDIRECT_URL = 'login'

 #Authentication backends
 AUTHENTICATION_BACKENDS = (
    'django.contrib.auth.backends.ModelBackend',
)

LANGUAGE_CODE = 'en-us'
TIME_ZONE = 'UTC'
USE_I18N = True
USE_L10N = True
USE_TZ = True

STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

1 Ответ

0 голосов
/ 17 мая 2019

У меня была похожая ошибка, и в журналах было указано ValueError: Missing staticfiles manifest entry for ...

Изменение STATICFILES_STORAGE в settings.py с:
STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
на:
STATICFILES_STORAGE = 'whitenoise.storage.CompressedStaticFilesStorage'
как описано в этом разделе белых документов исправлено для меня.

Также вы, вероятно, захотите изменить свой SECRET_KEY теперь, когда он открыт для общего доступа.

...