一、配置Media本地存储
默认情况下,Django 使用 MEDIA_ROOT
和 MEDIA_URL
设置本地存储,例如用户上传文件的保存位置。
Django 也提供编写自定义文件存储系统的方法,允许你完全自定义 Django 存储文件的位置和方式:传送门
1. MEDIA_ROOT
用来设置保存用户上传的文件的路径,该路径必须是绝对路径。它的默认值为 ''
(空字符串)。
-
例如:我们需要将上传的用户头像保存到
项目目录/media/avatar/
下,那么就需要:而在settings.py中设置:
MEDIA_ROOT = os.path.join(BASE_DIR,'media')
在模型的字段中设置:
avatar = models.ImageField(upload_to='avatar/')
这样,头像上传后,就会保存到
项目目录/media/avatar/
,但要注意的是:数据库保存的路径还是avatar/xxx.jpeg
。
另一个需要注意的地方是:MEDIA_ROOT
和 STATIC_ROOT
的值必须不同。
2. MEDIA_URL
用来设置访问MEDIA_ROOT
提供的媒体文件的 URL。默认为 ''
(空字符串),如果设置为非空值,则必须以斜线结束。
-
比如,在settings.py中:
MEDIA_URL = 'media/'
在开发和生产环境中,你都需要配置这些文件的服务,否则这些文件是不能被访问的。
-
补充:
使用
{% get_media_prefix %}
模板标签,可以很方便的在模板中获取到配置的MEDIA_URL
值。
二、开发期间为用户上传的媒体文件提供服务
开发期间,我们可以用 django.views.static.serve()
视图为用户上传的媒体文件提供服务:
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = [
# ... the rest of your URLconf goes here ...
] + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
这个方法不适合生产环境!常见的部署策略请参考官方文档:传送门。
注意:该函数只能在 debug 模式下生效,且要求前缀是本地的(例如 /static/
),不是一个 URL (例如 http://media.example.com/
)。