Django Heroku服务器错误页面500仅当Debug = False时,当Debug on True时一切正常。为什么?

时间:2018-04-16 19:37:44

标签: django heroku deployment

我的Djangoproject电话:myDebug 和我的Django应用程序调用:Deb

它在Heroku上:meindebug.herokuapp.com

settings.py

import os
import django_heroku 

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



SECRET_KEY = 'xxxxxxxxxxxxxxxxxxxxxxxxxxx'


DEBUG = False


ALLOWED_HOSTS = ['meindebug.herokuapp.com']

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'Deb',
]

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

ROOT_URLCONF = 'myDebug.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 = 'myDebug.wsgi.application'

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.sqlite3',
        'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
    }
}


AUTH_PASSWORD_VALIDATORS = [
    {
        'NAME': 'django.contrib.auth.password_validation.UserAttributeSimilarityValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.MinimumLengthValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.CommonPasswordValidator',
    },
    {
        'NAME': 'django.contrib.auth.password_validation.NumericPasswordValidator',
    },
]


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/2.0/howto/static-files/

STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATIC_URL = '/static/'

STATICFILES_DIRS = (
    os.path.join(BASE_DIR, 'static'),
)

STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

django_heroku.settings(locals())

!!!请注意我尝试了ALLOWED_HOSTS = [' *']但没有改变!!!

wsgi.py

import os

from django.core.wsgi import get_wsgi_application
from whitenoise import WhiteNoise

os.environ.setdefault("DJANGO_SETTINGS_MODULE", "myDebug.settings")

application = get_wsgi_application()
application = WhiteNoise(application, root='/static/Deb/Images/')
application.add_files('/static/Deb/Images/', prefix='more-files/')

Procfile

web: gunicorn myDebug.wsgi 

Pipfile

[[source]]
url = "https://pypi.python.org/simple"
verify_ssl = true
name = "pypi"

[packages]
gunicorn = "*"
django-heroku = "*"
whitenoise = "*"

[dev-packages]

[requires]
python_version = "3.6"

自从两周以来我试图解决这个问题。 不幸的是,我没有成功。

我找不到真正的修复。那里只有一些词,但没有人有真正的解决方案。

3 个答案:

答案 0 :(得分:0)

首先你必须运行python manage.py collectstatic。 然后在Heroku中将Config变量设置为COLLECTSTATIC = 1.

但是你的图片/文件的文件路径必须像这样显示

{% static "MyApp/Images/Picture.png" %}

如果你这么写就会出现错误

 {% static "/MyApp/Images/Picture.png" %}

MyApp前面的斜线是问题所在。所以写下它没有斜线然后它的工作原理。

如果头部有一个图标,那么你必须这样写

<link rel="shortcut icon" href="https://www.yourwebsite.de/static/MyApp/Images/favicon.ico">

答案 1 :(得分:0)

对于它的价值,如果您的代码中有一个html注释将模板标记称为“静态”(可能每个注释模板标记的行为都相同),那么您将面临同样的问题。 :

<!-- <img  src="{% static 'main_website/images/image.jpg' %}" alt=""> -->

删除注释可解决500错误(该错误也未记录)。

答案 2 :(得分:0)

我遇到了同样的问题,似乎我链接了一些 css 文件,但原始文件已被删除。请确保您没有链接任何不存在的外部文件。