- 一、配置Media本地存储
- 1. `MEDIA_ROOT`
- 2. `MEDIA_URL`
- 二、开发期间为用户上传的媒体文件提供服务
默认情况下,Django 使用 MEDIA_ROOT和 MEDIA_URL 设置本地存储,例如用户上传文件的保存位置。
1. MEDIA_ROOTDjango 也提供编写自定义文件存储系统的方法,允许你完全自定义 Django 存储文件的位置和方式:传送门
用来设置保存用户上传的文件的路径,该路径必须是绝对路径。它的默认值为 '' (空字符串)。
-
例如:我们需要将上传的用户头像保存到项目目录/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/)。



