我建立一个应用程序使用Django作为我的主力。到目前为止,一切都很好-指定的数据库设置,配置的静态目录,url,视图等。但是当我想要渲染自己漂亮的自定义404.html和500.html页面时,麻烦就来了。

我阅读了关于自定义错误处理的文档,并在UrlsConf中设置了必要的配置,创建了相应的视图,并将404.html和500.html添加到我的应用程序的模板目录(在settings.py中也指定了)。

但是文档说,在Debug关闭之前,您实际上可以查看自定义错误视图,所以我确实关闭了它来测试我的东西,而那就是事情变得疯狂的时候!

我不仅无法查看自定义404.html(实际上,它加载,但因为我的错误页面每个包含一个图形错误消息-作为一些漂亮的图像),错误页面的源加载,但没有其他加载!甚至没有链接CSS或Javascript!

一般来说,一旦我设置DEBUG = False,所有的视图将加载,但任何链接的内容(CSS, Javascript,图像等)不会加载!发生什么事情了?是否有什么东西我丢失了,关于静态文件和调试设置?


当前回答

实际上,你可以在Django生产应用程序中提供静态文件,而且不需要DEBUG=True。

不要使用Django本身,在你的WSGI文件(github)中使用dj_static:

让:

...
dj-static==0.0.6

YOURAPP/settings.py:

...
STATIC_ROOT = 'staticdir'
STATIC_URL = '/staticpath/'

YOURAPP/wsgi.py:

...
from django.core.wsgi import get_wsgi_application
from dj_static import Cling

application = Cling(get_wsgi_application())

其他回答

在urls.py中,我添加了这一行:

from django.views.static import serve 

在urlpatterns中添加这两个url:

url(r'^media/(?P<path>.*)$', serve,{'document_root': settings.MEDIA_ROOT}), 
url(r'^static/(?P<path>.*)$', serve,{'document_root': settings.STATIC_ROOT}), 

当DEBUG=FALSE时,静态文件和媒体文件都可以访问。

这是您在终端上运行项目时必须键入的,而不需要DEBUG = TRUE 然后你看到所有资产(静态)文件加载正确在本地服务器上。

python manage.py runserver --insecure 

——insecure:这意味着你可以在没有安全模式的情况下运行服务器

从这里我得到了一些帮助,混合了一些答案。这里,我把所有的部分相加。[我这样做是为了初学者的帮助,也是为了我将来的使用]

首先的问题是为什么需要Debug=False ! 我把我的项目放在AWS中,由于内存泄漏,几个小时后连接超时。 一开始我想用芹菜。[当然我只是个初学者] 然后把DEBUG=False从DEBUG=True改为DEBUG=False,正如我们在settings.py中看到的安全警告

# SECURITY WARNING: don't run with debug turned on in production!
DEBUG = True

一旦我这样做,我的静态文件在网页中加载不成功。 然后我到处搜索,首先尝试从这里——insecure命令运行服务器。

python manage.py runserver --insecure

这是成功的,但我不希望我的项目在生产时采用不安全模式。 在我看来,正确的解决方法是以下步骤。

首先,我纠正了settings.py中的静态URL、根目录和目录

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

然后通过命令收集静态文件

python manage.py collectstatic

现在是第二步,[这里也提供了] 首先在命令行中的项目目录中安装白噪声

pip install whitenoise

然后添加'whitenoise.middleware。在settings.py中中间件列表中的WhiteNoiseMiddleware'。

这应该添加在django.middleware.security下面。SecurityMiddleware'以及所有其他中间件。这样你的中间件列表看起来就像这样:-

MIDDLEWARE = [
    'django.middleware.security.SecurityMiddleware', #after this line
    'whitenoise.middleware.WhiteNoiseMiddleware', #add it exactlyhere
    'django.contrib.sessions.middleware.SessionMiddleware', #before this
    '...'
]

在你安装的应用程序顶部添加'whitenoise.runserver_nostatic',这样你安装的应用程序列表将看起来像这样

INSTALLED_APPS = [
    'whitenoise.runserver_nostatic',
    'django.contrib.admin',
    'django.contrib.auth',
    '...'
]

完成后,您现在就可以在生产环境中提供静态文件了!![我对我当地的环境也是这样做的]

只要像往常一样使用runserver命令,不需要任何不安全或其他任何东西。

python manage.py runserver

繁荣! !这对我很有用。 哈哈哈。我知道我有点孩子气,但我现在很开心。

感谢所有在这里提供答案并帮助我工作的人。

对于Django的最新版本,请查看这里的答案:https://stackoverflow.com/a/7639983/6180987

对于django 1.10以下的版本,解决方案应该工作:

只要打开你的项目urls.py,然后找到这个if语句。

if settings.DEBUG:
    urlpatterns += patterns(
        'django.views.static',
        (r'^media/(?P<path>.*)','serve',{'document_root': settings.MEDIA_ROOT}), )

您可以更改设置。DEBUG设为True,它将始终工作。但如果你的项目是一个严重的问题,那么你应该考虑上面提到的其他解决方案。

if True:
    urlpatterns += patterns(
        'django.views.static',
        (r'^media/(?P<path>.*)','serve',{'document_root': settings.MEDIA_ROOT}), )

在django 1.10中,你可以这样写:

urlpatterns += [ url(r'^media/(?P<path>.*)$', serve, { 'document_root': settings.MEDIA_ROOT, }), url(r'^static/(?P<path>.*)$', serve, { 'document_root': settings.STATIC_ROOT }), ]

实际上,你可以在Django生产应用程序中提供静态文件,而且不需要DEBUG=True。

不要使用Django本身,在你的WSGI文件(github)中使用dj_static:

让:

...
dj-static==0.0.6

YOURAPP/settings.py:

...
STATIC_ROOT = 'staticdir'
STATIC_URL = '/staticpath/'

YOURAPP/wsgi.py:

...
from django.core.wsgi import get_wsgi_application
from dj_static import Cling

application = Cling(get_wsgi_application())