设置DEBUG = False会导致500错误


298

有一次,我改变DEBUG = False,我的网站将产生500(使用WSGI和manage.py runserver命令),并且在Apache的错误日志中没有错误信息,当我改变它通常会运行debugTrue

我正在使用Django 1.5和Python 2.7.3,这是Apache访问日志,并且在apache错误日志中没有任何日志

www.beta800.net:80 222.247.56.11 - - [28/Feb/2013:13:42:28 +0800] "GET / HTTP/1.1" 500 257 "-" "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.97 Safari/537.22"
www.beta800.net:80 222.247.56.11 - - [28/Feb/2013:13:42:28 +0800] "GET /favicon.ico HTTP/1.1" 500 257 "-" "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.97 Safari/537.22"
www.beta800.net:80 222.247.56.11 - - [28/Feb/2013:13:42:28 +0800] "GET /favicon.ico HTTP/1.1" 500 257 "-" "Mozilla/5.0 (Windows NT 6.2; WOW64) AppleWebKit/537.22 (KHTML, like Gecko) Chrome/25.0.1364.97 Safari/537.22"

这是我的设置文件:

import os.path    
DEBUG = False 
#TEMPLATE_DEBUG = DEBUG

HERE = os.path.dirname(__file__)
ADMINS = (
    ('admin', 'xyzadmin@qq.com'),
)

MANAGERS = ADMINS

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
        'NAME': 'zdm',                      # Or path to database file if using sqlite3.
        'USER': 'root',                      # Not used with sqlite3.
        'PASSWORD': 'passwd',                  # Not used with sqlite3.
        'HOST': '',                      # Set to empty string for localhost. Not used with sqlite3.
        'PORT': '',                      # Set to empty string for default. Not used with sqlite3.
    }
}

# Local time zone for this installation. Choices can be found here:
# http://en.wikipedia.org/wiki/List_of_tz_zones_by_name
# although not all choices may be available on all operating systems.
# In a Windows environment this must be set to your system time zone.
TIME_ZONE = 'America/Chicago'

# Language code for this installation. All choices can be found here:
# http://www.i18nguy.com/unicode/language-identifiers.html
LANGUAGE_CODE = 'en-us'

SITE_ID = 1

# If you set this to False, Django will make some optimizations so as not
# to load the internationalization machinery.
USE_I18N = True

# If you set this to False, Django will not format dates, numbers and
# calendars according to the current locale.
USE_L10N = True

# If you set this to False, Django will not use timezone-aware datetimes.
USE_TZ = True

# Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/home/media/media.lawrence.com/media/"
MEDIA_ROOT = ''

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash.
# Examples: "http://media.lawrence.com/media/", "http://example.com/media/"
MEDIA_URL = ''

# Absolute path to the directory static files should be collected to.
# Don't put anything in this directory yourself; store your static files
# in apps' "static/" subdirectories and in STATICFILES_DIRS.
# Example: "/home/media/media.lawrence.com/static/"
#STATIC_ROOT = os.path.join(HERE, 'static').replace('\\','/')

# URL prefix for static files.
# Example: "http://media.lawrence.com/static/"
STATIC_URL = '/static/'
#STATIC_ROOT = os.path.join(HERE, 'static').replace('\\','/')
S= os.path.join(HERE, 'static').replace('\\','/')

# Additional locations of static files
STATICFILES_DIRS = (
    # Put strings here, like "/home/html/static" or "C:/www/django/static".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
    '/home/zdm/static',
)

# List of finder classes that know how to find static files in
# various locations.
STATICFILES_FINDERS = (
    'django.contrib.staticfiles.finders.FileSystemFinder',
    'django.contrib.staticfiles.finders.AppDirectoriesFinder',
#    'django.contrib.staticfiles.finders.DefaultStorageFinder',
)

# Make this unique, and don't share it with anybody.
SECRET_KEY = '9a7!^gp8ojyk-^^d@*whuw!0rml+r+uaie4ur$(do9zz_6!hy0'

# List of callables that know how to import templates from various sources.
TEMPLATE_LOADERS = (
    'django.template.loaders.filesystem.Loader',
    'django.template.loaders.app_directories.Loader',
#     'django.template.loaders.eggs.Loader',
)

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.middleware.csrf.CsrfViewMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.contrib.messages.middleware.MessageMiddleware',
    # Uncomment the next line for simple clickjacking protection:
    # 'django.middleware.clickjacking.XFrameOptionsMiddleware',
)

ROOT_URLCONF = 'zdm.urls'

# Python dotted path to the WSGI application used by Django's runserver.
WSGI_APPLICATION = 'zdm.wsgi.application'

TEMPLATE_DIRS = (
    # Put strings here, like "/home/html/django_templates" or "C:/www/django/templates".
    # Always use forward slashes, even on Windows.
    # Don't forget to use absolute paths, not relative paths.
    '/home/zdm/templates',
)

INSTALLED_APPS = (
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.sites',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    # Uncomment the next line to enable the admin:
    'django.contrib.admin',
    # Uncomment the next line to enable admin documentation:
    # 'django.contrib.admindocs',
    'zdm',
    'portal',
    'admin',
    'tagging',
)

是的,我在模板目录中添加了403和404 500 html文件
zhiguo.wang

您是否有500.html和404.html和403.html文件?我想我记得在我的模板目录的根目录中没有那些文件的已部署项目存在问题。
esse

如果您的网站正在产生500错误,则Apache日志中应该包含一些信息,您可能希望将错误日志文件末尾的一部分粘贴下来,以供人们查看。
esse

87
您可能现在想更改SECRET_KEY,因为它已经公开可用了
Fraxtil 2013年

1
这不是每个人的答案。如以下stackoverflow.com/a/372​​18484/4028977中所示,可能有许多原因导致这种情况发生。通过一些简单的日志记录,您无需进行猜测即可查找。
罗布

Answers:


413

Django 1.5引入了出于安全原因所需的允许主机设置。使用Django 1.5创建的设置文件具有此新部分,您需要添加该部分:

# Hosts/domain names that are valid for this site; required if DEBUG is False
# See https://docs.djangoproject.com/en/1.9/ref/settings/#allowed-hosts
ALLOWED_HOSTS = []

在此处添加主机['www.beta800.net']['*']用于快速测试,但请勿['*']用于生产


32
哇-这让我们很难受。确实令人讨厌的是,此设置被埋在文档中。我们的生产站点不适用于DEBUG = False。谢谢你指出这一点!!!
shreddd

4
有关引入此设置的安全性问题的更多信息:实用的HTTP Host标头攻击。一定会说服您不要['*']在生产中使用。
gertvdijk

4
bl。令人讨厌的是,他们甚至没有将它作为settings.py中的默认值使用,也许带有一个宽泛的注释……
hwjp

7
有时我想知道为什么Django变得越来越弱智!奇怪的是,这些人比我更好的程序员,但是当真正正确的方法是正确配置服务器时,我真的不理解在应用程序级别“修复”漏洞的决定。“模板缓存”和“持久连接”也是如此……无用的代码永远不会在严肃的网站中使用;仍然被视为编程的圣杯!也许只是我,以前我做错了!
StefanNch 2014年

3
没关系,发现了问题。django-pipeline尚未收集静态信息时,这与的行为有关。作为一般提示,在Django的handle_uncaught_exception方法中放置一个断点将帮助您弄清楚这里发生了什么。
彼得

51

我知道这很晚了,但是我最终在这里搜索了错误500 DEBUG=False,在我的情况下确实是,ALLOWED_HOSTS但是我os.environ.get('variable')用来填充主机,直到启用日志记录后我才注意到这一点,您可以将所有错误记录到下面的文件中,即使发生以下情况,它也会记录下来DEBUG=False

# settings.py
LOGGING = {
    'version': 1,
    'disable_existing_loggers': False,
    'formatters': {
        'verbose': {
            'format' : "[%(asctime)s] %(levelname)s [%(name)s:%(lineno)s] %(message)s",
            'datefmt' : "%d/%b/%Y %H:%M:%S"
        },
        'simple': {
            'format': '%(levelname)s %(message)s'
        },
    },
    'handlers': {
        'file': {
            'level': 'DEBUG',
            'class': 'logging.FileHandler',
            'filename': 'mysite.log',
            'formatter': 'verbose'
        },
    },
    'loggers': {
        'django': {
            'handlers':['file'],
            'propagate': True,
            'level':'DEBUG',
        },
        'MYAPP': {
            'handlers': ['file'],
            'level': 'DEBUG',
        },
    }
}

16
这应该是公认的答案。在使用生产设置后,简单地询问框架本身有什么问题,而不是尝试猜测,这会更加有用。
Stefan Dragnev

4
确实,这不是在黑暗中徘徊的东西。只需查看使用此方法通常会看到的错误消息即可。就我而言,我在我的应用程序所寻找的settings.py中缺少其他设置。我所需要的只是日志来进行追踪。重要说明:我在'mysite.log'之前添加了/ path / to / my / django /,如docs示例所示:docs.djangoproject.com/en/1.10/topics/logging/#examples
Rob

4
我花了几个小时寻找解决方案,没有用。根据此答案,只需使用日志记录,您应该就会遇到问题,这是最好的答案。谢谢OP!
堆叠

我的服务器错误似乎没有产生任何日志!我尝试了各种日志记录配置,但无济于事。有任何想法吗?
cammil

5
谢谢!这解决了我的错误。原来,我需要运行collectstatic来从程序包中收集一些静态资产。
themessup19年

33

我最近在Django 2.0中遇到了相同的问题。我可以通过设置找出问题DEBUG_PROPAGATE_EXCEPTIONS = True。参见此处:https : //docs.djangoproject.com/en/2.0/ref/settings/#debug-propagate-exceptions

就我而言,错误是ValueError: Missing staticfiles manifest entry for 'admin/css/base.css'。我通过本地运行来解决此问题python manage.py collectstatic


我做同样的事情,但是Collectstatic并没有为我解决它。您是否收到“无法达到的错误”?在这种情况下,您是如何解决的?
卡维·瓦迪亚

23

以我为例,阅读第三方应用程序的文档正确地救了我。

罪魁祸首?django_compressor

我有

{% load compress %}
{% compress css %}
 ... css files linked here ..
{% endcompress %}

DEBUG = True 总是给我500。要解决它,我需要在设置中添加一行以使其运行

COMPRESS_ENABLED = os.environ.get('COMPRESS_ENABLED', False)

谢谢,那是它对我不起作用的原因,但是那条线不使django_compressor无法执行其工作吗?
Fanckush

1
@Fanckush Nope。不涉及任何伤害。django-compressor.readthedocs.io/en/latest/settings / ... Compressor仍将完美地完成其工作!只需压缩所有静态变量(如CSS),就可以使设置无用,因为您的资产已被压缩
KhoPhi

13

正确,在Django 1.5中,如果DEBUG = False,则配置ALLOWED_HOSTS,添加不带端口号的域。例:

ALLOWED_HOSTS = ['localhost']

出于某种原因,使用“ localhost”对我不起作用。我不得不改用IP'127.0.0.1'。如果您吓坏了,只是想让它工作,我也可以使用“ *”。我不建议在生产中这样做。运行Django 1.4.20的OSX
BlakePetersen

11

您还必须检查所有地方的URL。当将DEBUG设置False为时,所有不带尾随的URL /都将被视为一个错误,这与您具有时不同DEBUG = True,在这种情况下,Django将/在缺少它的所有位置附加。因此,简而言之,请确保所有链接都以斜线“ EVERYWHEREHERE”结尾。


3
只需使用反向和url标签,就可以了
Maazza 2013年

设置DEBUG=False也可以揭示导入错误:stackoverflow.com/questions/25676453/…–
ecoe

甚至链接到js和CSS资产?
amchugh89 2015年

@ amchugh89:不,仅是“ django” URL
webzy

1
我的问题是,whitenoise无法找到某些图像,并抛出ValueError。我也找不到它,但不知道如何告诉白噪声不要寻找它。所以我关闭了whitenoise,使用Django静态服务,现在我可以在产品中运行debug = False了。显然不理想:(
amchugh89,2015年

7

我有一个有趣的故事。到达此页面后,我说:“尤里卡!我得救了。那一定是我的问题。” 所以我将所需的ALLOWED_HOSTS列表插入到setting.py中,什么也没有。相同的旧500错误。不,不是因为缺少404.html文件。

所以有两天,我忙于野蛮的理论,例如它与提供静态文件有关(请理解我是一个菜鸟,而菜鸟不知道他们在做什么)。

那是什么 现在是主持人先生,我们提供了一个有用的提示。我的开发Django版本为1.5.something,而我的生产服务器版本为1.5.something + 1 ...或加2。因此,在ALLOWED_HOSTS将桌面版本的settings.py添加到桌面后,它缺少hwjp所要求的内容-“ settings.py中的默认值,也许带有解释性注释”-我在生产服务器上执行了以下操作:适当的域名。

但是我没有注意到在带有更高版本Django的生产服务器上,settings.py中有一个默认值,带有解释性注释。在监视器的视线范围内,它远低于我进入的位置。当然,列表是空的。因此,我浪费时间。


1
我有完全相同的搞笑模式!,除了只有在我发现这一点之后,它才变得搞笑起来,谢谢。在此之前,这简直令人沮丧
binithb 2013年

在所有这些操作中有帮助的一点是local_settings.py对每个环境使用a ,然后将其导入settings.py
nicorellius 2013年

1
我想做的是有一个settings / 目录,而不是settings.py。在此目录中,您可以为不同的环境使用单独的.py文件,并为常规设置使用base.py。然后,取决于生产的设置可以从基本设置中导入*开始,然后覆盖它们需要覆盖的所有内容。另外,将该settings /目录转换为有效模块所需的init .py可以首先从base.py导入,然后尝试从local.py(仅在本地存在)导入。这意味着您不需要手动指定本地设置
mephisto 2014年

7

补充主要答案在开发和生产之间切换时
更改ALLOWED_HOSTS和DEBUG全局常量很烦人settings.py。我正在使用此代码自动设置以下设置:

import socket

if socket.gethostname() == "server_name":
    DEBUG = False
    ALLOWED_HOSTS = [".your_domain_name.com",]
    ...
else:
    DEBUG = True
    ALLOWED_HOSTS = ["localhost", "127.0.0.1",]
    ...

如果使用macOS,则可以编写更通用的代码:

if socket.gethostname().endswith(".local"): # True in your local computer
    DEBUG = True
    ALLOWED_HOSTS = ["localhost", "127.0.0.1",]
else:
    ...

6

对于它的价值-我DEBUG = False仅在某些页面上获得500 。用pdb追溯异常发现资产丢失(我怀疑{% static ... %}模板标签是500的元凶。


1
这也是我的问题,自定义404页所引用的基本模板使用了静态标记,但顶部没有包含{%load static%}。我没有在其他地方注意到它,因为我的其他模板都具有这一行,但是无论如何都将其放在基础中是有意义的,因为它在各处都指向静态文件。
krischan

2
此处的解决方案相同-我当时使用的static是包含一个不存在的CSS文件。
Phil Gyford '16

5

我这样做的时候也遇到了同样的问题DEBUG = FALSE。这是一个综合解决方案,分散在上述答案和其他帖子中。

默认情况下,在settings.py中有ALLOWED_HOSTS = []。您可能需要ALLOWED_HOSTS根据方案进行价值调整,以消除错误:

1:您的域名:

ALLOWED_HOSTS = ['www.example.com'] # Your domain name here

2:如果您还没有域名,那么将使用已部署的服务器IP(这是我的情况,非常有用):

ALLOWED_HOSTS = ['123.123.198.123'] # Enter your IP here

3:如果要在本地服务器上进行测试,则可以将settings.py或修改settings_local.py为:

ALLOWED_HOSTS = ['localhost', '127.0.0.1']

4:您还可以在ALLOWED_HOSTS值中提供“ *”,但出于安全原因,不建议在生产环境中使用它:

ALLOWED_HOSTS = ['*'] # Not recommended in production environment

我还在我的博客上发布了详细的解决方案,您可能希望参考。


5

ALLOWED_HOSTS不是唯一的问题,对我来说,我必须创建一个404.html并将其放在模板的基本级别(而非应用程序级别)中-另外,您可以创建404视图并添加404handler网址,但我认为可选的。404.html修复了它

在mainproject.urls中

handler404 = 'app.views.custom_404'

在app.views中

def custom_404(request):
    return render(request, '404.html', {}, status=404)

然后制作一个template / 404.html模板

从另一个我无法找到的S / O帖子获得了它

编辑

同样,使用白噪声投放资产时会出现500个错误。无法弄清楚我的一生,错误是whitenoise的ValueError无法找到我也找不到的资产,必须暂时使用默认的Django服务


8
我对白噪声也有同样的问题。python manage.py collectstatic固定它。
Eugene Pakhomov

1
@ amchungh89您是救生员!感谢您指出这一点。
Deepak Sharma

5

我正在搜索和测试有关此问题的更多信息,我意识到在settings.py中指定的静态文件目录可能是导致此问题的原因,因此,首先,我们需要运行此命令

python manage.py collectstatic

在settings.py中,代码应如下所示:

STATIC_URL = '/static/'

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

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

3

我知道这是一个非常老的问题,但也许我可以帮助其他人。如果在设置DEBUG = False后出现500错误,则始终可以在命令行中运行manage.py runserver来查看任何不会出现在任何Web错误日志中的错误。


2

它在2019年中期,在与Django一起开发了几年之后,我遇到了这个错误。让我困惑了一整晚!不允许主机(应该抛出400),其他所有内容都检出了,最后做了一些错误记录,只是发现一些丢失的或弄乱的静态文件清单(在collectstatic之后)正在搞乱安装程序。长话短说,对于那些陷入困境而正在使用WHEITENOISE或DJANGO STATICFILE后端(带有CACHE)的人(清单静态文件),也许这是给您的。

  1. 确保您设置了所有内容(就像我为whitenoise后端所做的操作一样... django后端仍在阅读) http://whitenoise.evans.io/en/stable/django.html

  2. 如果错误代码500仍然使您失望,请注意您的settings.STATICFILES_STORAGE。

将其设置为任一(用于压缩后的白噪声后端)

STATICFILES_STORAGE = 'whitenoise.storage.CompressedStaticFilesStorage'

或(保留为django默认)

STATICFILES_STORAGE = django.contrib.staticfiles.storage.StaticFilesStorage

总而言之,问题似乎来自这个白噪声缓存+压缩后端->

STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

还是django自己的缓存后端->

STATICFILES_STORAGE = 'django.contrib.staticfiles.storage.ManifestStaticFilesStorage'

...这对我来说效果很好,因为我的CSS引用了其他一些可能在collectstatic /后端缓存过程中混淆的来源。http://whitenoise.evans.io/en/stable/django.html#storage-troubleshoot中也可能会突出显示此问题


1

我认为也可能是http服务器设置。我的仍然很破损,整个时间都保持ALLOWED_HOSTS。我可以在本地访问它(我使用gunicorn),但是当DEBUG = False时不能通过域名访问它。当我尝试使用域名时,它给了我错误提示,因此让我认为这是与Nginx相关的问题。

这是我的nginx的conf文件:

server {
    listen   80;
    server_name localhost myproject.ca www.myproject.ca;
    root /var/web/myproject/deli_cms;

    # serve directly - analogous for static/staticfiles
    location /media/ {
        # if asset versioning is used
        if ($query_string) {
            expires max;
        }
    }
    location /admin/media/ {
        # this changes depending on your python version
        root /var/web/myproject/lib/python2.6/site-packages/django/contrib;
    }
    location /static/ {
    alias /var/web/myproject/deli_cms/static_root/;
    }

    location / {
        proxy_pass_header Server;
        proxy_set_header Host $http_host;
        proxy_redirect off;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Scheme $scheme;
        proxy_connect_timeout 10;
        proxy_read_timeout 10;
        proxy_pass http://localhost:8000/;
    }
    # what to serve if upstream is not available or crashes
    error_page 500 502 503 504 /media/50x.html;
}

我的gunicorn配置文件如下:#!/ bin / bash cd / var / web / delicms_env / deli_cms / source ../bin/activate exec gunicorn --workers = 3 deli_cms.wsgi:application
user2868304 2013年

我的问题现在已经解决,我正在使用gunicorn_django脚本,它给了我不赞成使用的消息。仍然不确定为什么它可以在本地运行,没有更改我的nginx配置,只是将旧脚本更改为使用gunicorn并使用了wsgi:application模块,它可以再次运行。在此之前,Gunicorn也抛出了一些弃用消息,但没有关于我的问题的消息。
user2868304


1

我遇到了这个问题。原来,我是使用statictemplate标记包含在模板中的,该文件不再存在。查看日志可以发现问题所在。

我想这只是这种错误的许多可能原因之一。

故事的寓意:始终记录错误并始终检查日志。


1

感谢@squarebear,在日志文件中,我发现了错误: ValueError: The file 'myapp/styles.css' could not be found with <whitenoise.storage.CompressedManifestStaticFilesStorage ...>

django应用程序出现了一些问题。我删除了
STATICFILES_STORAGE = 'whitenoise.django.GzipManifestStaticFilesStorage'从heroku文档中找到的行。

我也不得不在django应用程序的根目录中添加额外的目录(由于另一个SO回答staticmyapp/static即使我没有使用它也是如此。然后python manage.py collectstatic在运行服务器之前运行命令即可解决问题。最终,它开始正常运行。


这如何回答原始问题?
尼克

1

我开始以以下形式获取500 for debug = False

django.urls.exceptions.NoReverseMatch: Reverse for 'home' not found.
or...
django.urls.exceptions.NoReverseMatch: Reverse for 'about' not found.

当引发django.core.exceptions.ValidationError而不是引发rest_framework.serializers.ValidationError时

公平地讲,它之前已经提高了500,但是作为ValidationError(带有debug = False),将其更改为NoReverseMatch。


1

这也许可以帮助其他人,就我而言,缺少网站图标的问题。


0

我知道这是一个老问题,但是当DEBUG = False时,我也遇到500错误。几个小时后,我意识到我忘了在base.html中的某些链接后面加上斜杠。


甚至CSS和JS的东西?
amchugh89 2015年

0

这是旧的,我的问题最终与该问题有关,但与OP无关,但我的解决方案适用于其他尝试以上操作均无济于事的人。

我在Django的修改版本中进行了设置,以最小化仅在DEBUG关闭时才运行的CSS和JS文件。我的服务器没有安装CSS缩小器,并抛出了错误。如果您使用的是Django-Mako-Plus,则可能是您的问题。


0

需要注意的一点是,如果数组中没有None,则所有后续允许的主机都将被忽略。

ALLOWED_HOSTS = [
    "localhost",
    None,
    'example.com', # First DNS alias (set up in the app)
    #'www.example.com', # Second DNS alias (set up in the app)
]

Django version 1.8.4


0

派对晚了一点,当然可能会有很多问题,但是我遇到了类似的问题,结果发现我的html注释中有{%%}个特殊字符...

<!-- <img src="{% static "my_app/myexample.jpg" %}" alt="My image"/> -->

0

我有一种观点认为在debug = false中引发了500错误,但在debug = true中起作用。对于任何遇到这种问题的人,“允许的主机”都不是问题,我通过更新模板的静态标记(指向错误的位置)来修复视图。

因此,我建议您仅检查所使用的任何模板中的链接和标签是否密封,也许某些东西在调试时会漏网,但会给生产带来错误。


0

当DEBUG = False时,我发现了500错误的另一个原因。我使用Django compressor实用程序,我们的前端工程师在Django模板的一个块添加了对字体文件的引用compress css。像这样:

{% compress css %}
    <link href="{% static "css/bootstrap.css" %}" rel="stylesheet">
    <link href="{% static "css/bootstrap-spinedit.css" %}" rel="stylesheet">
    <link href="{% static "djangular/css/styles.css" %}" rel="stylesheet">
    <link href="{% static "fonts/fontawesome-webfont.ttf" %}" rel="stylesheet">
{% endcompress %}

解决方案是将链接移至ttfendcompress行下方的文件。


0

我有一个与此类似的问题,我将报告如何解决我的问题,因为可能有人也遇到了同样的问题。

就我而言,该错误是由于服务器未从主页中找到一些静态文件引起的。

因此,请确保错误仅出现在index或另一页上。如果仅在索引中出现问题,则很有可能需要检查静态文件。我建议打开Chrome预览控制台并检查是否有错误。

就我而言,服务器找不到favicon.ico另外两个CSS。

为了解决这个问题,我通过了python manage.py collectstatic,它奏效了。


0

我知道这篇文章已经很老了,但是今天仍然很贴切。

对于它的价值- DEBUG = False我的网站上所有页面的总价值为500 。

在调试时没有回溯。

我必须遍历站点内模板中的每个静态链接,并在图像源前面找到一个/(正斜杠)。{% 静态的 ... %}。这造成了500错误,DEBUG = False但工作正常Debug = True,没有任何错误。很烦人!被警告!由于正斜杠浪费了很多时间。


0

python manage.py collectstatic设置DEBUG = FalseALLOWED_HOSTS = ['127.0.0.1']进入后,您可能要运行settings.py。经过这两个步骤后,即使使用DEBUG = False模式,我的Web应用程序也可以在本地服务器上正常运行。

顺便说一句,我在中有这些设置settings.py

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware',
    'whitenoise.middleware.WhiteNoiseMiddleware', # what i added
    'django.middleware.common.CommonMiddleware', # and so on...
]

STATICFILES_STORAGE = 'whitenoise.storage.CompressedManifestStaticFilesStorage'

我认为也许白噪声设置与collectstatic命令有关。


-3

确定,尝试了很多事情之后,正确的解决方案是...

您需要设置DEBUG = 'FALSE'FalseFALSE,但'FALSE'''


我认为'FALSE'是一个字符串,所以它等于True,这就是为什么它没有得到错误的原因。
13:47 pet
By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.