静态文件问题导致django 500错误?

时间:2018-06-29 19:05:13

标签: python django angular heroku whitenoise

我正在使用有角的heroku和django。我一直注意到,当我使用“ ng build”构建新的静态文件以添加到django然后推送到heroku时,heroku实例显示的网站比我当前的代码落后多个版本。

我今天ngbuild将文件放在指定的文件夹中后,尝试运行django本地服务器,

运行python manage.py collectstatic

它成功运行。

然后我运行django服务器,导航到我的页面,并得到500响应。

因为我使用的是angular,所以我将django服务器设置为rest后端。

其余服务使用的每个端点都以url api /

开头

so localdomain / api / <-宁静的服务

localdomain单独提供有角度的应用程序。

当我尝试提供该应用程序时,我只会收到500服务器错误。

这是我所有有关静态文件的设置:

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'whitenoise.middleware.WhiteNoiseMiddleware',

#angular distro root
ANGULAR_APP_DIR = os.path.join(BASE_DIR, 'frontend/dist/')
#image distro root
ASSETS_DIR = os.path.join(BASE_DIR, 'frontend/dist/assets/')


# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.11/howto/static-files/
#STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'
STATICFILES_STORAGE = 'whitenoise.django.GzipManifestStaticFilesStorage'
STATIC_ROOT = os.path.join(BASE_DIR, 'staticfiles')
STATIC_URL = '/static/'

STATICFILES_DIRS = [
    os.path.join(ANGULAR_APP_DIR),
    os.path.join(ASSETS_DIR),

]

我的模板设置:

ROOT_URLCONF = 'suitsandtables.urls'

TEMPLATES = [
    {
        'BACKEND': 'django.template.backends.django.DjangoTemplates',
        'DIRS': ['suitsandtables/templates',
                 'stemail/templates'],
        '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',
            ],
        },
    },
]

我的网址(用于提供静态文件)和我的网址(用于呈现index.html页面)

url(r'^(?!/?static/)(?!/?media/)(?P<path>.*\..*)$',
        RedirectView.as_view(url='/static/%(path)s', permanent=False)),
 url(r'^$', views.RootView.as_view()),

我的rootview类呈现index.html

class RootView(TemplateView):
    def get(self, request, **kwargs):
        return render(request, 'index.html', context = None)

1 个答案:

答案 0 :(得分:0)

这是白噪声的常见问题。我为此浪费了无数小时。这是解决该问题的方法。

将这两行放入您的settings.py

DEBUG = False
DEBUG_PROPAGATE_EXCEPTIONS = True

并尝试在heroku上运行该应用程序。它将像往常一样破裂。

现在转到

https://dashboard.heroku.com/apps/<app_name>/logs

通常,当调试为False 时,您将看不到日志,但是由于 DEBUG_PROPAGATE_EXCEPTIONS = True ,您可以看到日志

在这里,寻找whitenoise找不到的文件,并使whitenoise成为麻烦。在我的情况下,这是我 base.html 中引用的一些随机CSS文件。

您可以固定其位置,也可以直接从base.html中删除引用此文件的行。

此后,如果其他文件有问题,请继续进行操作。

最终白噪声会很高兴,你也会如此。