使用 MEDIA_URL 和 MEDIA_ROOT 解决 Django 媒体文件服务问题
尝试通过 Django 管理界面上传图像并通过 URL 访问它时或者在前端,如果你的设置不正确,你可能会遇到令人沮丧的 404 错误
MEDIA_ROOT 和 MEDIA_URL 设置
为了存储上传的媒体文件,Django 使用两个设置: MEDIA_ROOT,它指定文件所在的物理目录的路径MEDIA_URL,它是用于访问存储上的文件的 URL 前缀web.
在您的情况下,您已将 MEDIA_ROOT 设置为 /home/dan/mysite/media/ 并将 MEDIA_URL 设置为 /media/,看起来一切都设置正确。但是,在配置 URL 模式来提供这些文件之前,您仍然无法访问上传的文件。
在开发中提供静态文件
本地开发时Django,提供像图像这样的静态文件是必不可少的。然而,在生产中,您通常需要配置 Web 服务器(例如 Apache 或 Nginx)来处理静态文件服务。
对于开发,Django 提供了可以使用的 django.views.static.serve 函数提供指定目录中的文件。要将其集成到您的 Django 项目中,请按照以下步骤操作:
更新您的设置:
from django.conf import settings if settings.DEBUG: # static files (images, css, javascript, etc.) urlpatterns += patterns('', (r'^media/(?P<path>.*)$', 'django.views.static.serve', { 'document_root': settings.MEDIA_ROOT}))
这将确保当 DEBUG 为 True 时(通常是本地开发期间的情况),Django 将从以下位置提供静态文件MEDIA_ROOT 目录。
访问图像
正确配置 URL 模式后,您现在可以使用 URL 前缀 MEDIA_URL 后接路径来访问上传的图像文件。在您的情况下,您可以通过 http://127.0.0.1:8000/media/images/myimage.png 访问该图像。
以上是即使设置了 MEDIA_ROOT 和 MEDIA_URL,为什么我在尝试访问上传的 Django 媒体文件时仍会收到 404 错误?的详细内容。更多信息请关注PHP中文网其他相关文章!