快速解决Django关闭Debug模式无法加载media图片与static静态文件
开发时,通常打开Debug模式会快速定位开发时的一些问题。
项目开始部署时,关闭Debug模式,url.py路由静态文件和图片写法:
# url.py from django.views import static from django.conf import settings #路由静态文件和图片 urlpatterns = [ url(r'^static/(?P<path>.*)$', static.serve, {'document_root': settings.STATIC_ROOT}, name='media') url(r'^media/(?P<path>.*)$', static.serve, {'document_root': settings.MEDIA_ROOT}, name='media') ]
补充知识:Django静态文件的获取,以及对static和media目录设置的一些思考
Django直接获取静态资源文件是不行的,会报错。
添加静态资源文件夹static,设置静态文件根目录后
INSTALLED_APPS = [ ... 'django.contrib.staticfiles', ... ] # Static files (CSS, JavaScript, Images) # https://docs.djangoproject.com/en/3.0/howto/static-files/ STATIC_URL = '/static/' # 可收集静态文件到static文件夹,便于访问 STATICFILES_DIRS = [ os.path.join(BASE_DIR, 'static') ]
配置完成后就可以通过下面的代码调用静态资源了。图片、css、js文件。
{% load static %} ... ... <img class="author_img rounded-circle" src="{% static 'image/blog/author.png' %}" alt="" >
但是上传到media中的文件可以不通过这种方式调用。但是前提是也要配置media的文件根路径和根目录。
MEDIA_URL = '/media/' # 访问文件的url根路径
MEDIA_ROOT = os.path.join(BASE_DIR, 'media') # 上传文件存储根目录
然后可以通过如下方法调用。
<img class="img-fluid" src="/media/{{ detop_view.cover_photo }} " alt="post">
可以注意到这里资源引用没有用{% static ... %},实际上只要这样子在settings.py文件中配置了相关路径和目录,就可以通过这种方式引用。
要是别的静态文件都通过这种方法引用,对于小项目这不是什么问题,你可以将静态文件放在任何你的web服务器能够找到的地方。但是对于大型项目,尤其是那些包含多个app在内的项目,处理那些由app带来的多套不同的静态文件是个麻烦活。但这正是django.contrib.staticfiles的用途:它收集每个应用(和任何你指定的地方)的静态文件到一个统一指定的地方,并且易于访问。
media目录下一般放上传的文件,在django项目部署到服务器的时候,会输入python manage.py collectstatic收集静态资源文件,所以与static目录不冲突,而且media中的文件可能还会被删除。因此后期用户上传的文件不放在static目录下。
以上这篇快速解决Django关闭Debug模式无法加载media图片与static静态文件就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。