【Django】上传图片之路径问题
来源:互联网 发布:西城区2016年经济数据 编辑:程序博客网 时间:2024/06/07 02:41
问题描述
在debug模式下,访问路径「http://127.0.0.1/media/images/logo.png
」出现404错误。
而不是预想中可以显示到图片。
(如果想要显示图片,则需要将图片放到某个app下的media/images目录下,即http://127.0.0.1/myapp/images/logo.png
,这显然和我们的预期目的不符)
配置
在
settings.py
中设置:MEDIA_ROOT = os.path.join(BASE_DIR,'media')
MEDIA_URL = '/media/'在
models.py
中设置id_front_image = models.ImageField(upload_to='.', max_length=255, null=True, blank=True)
结果
- 图片可以得到正确的存放路径。
/home/lou/mysite/media/logo.png
- 但是在URL中访问
http://127.0.0.1/medias/images/logo.png
得到404错误。
解决办法
根据官方文档(https://docs.djangoproject.com/en/1.5/howto/static-files/#serving-files-uploaded-by-a-user
)中的说法,有很好的解决办法即在urls.py中添加一段代码:
>
Serving files uploaded by a user¶
During development, you can serve user-uploaded media files from MEDIA_ROOT using thedjango.contrib.staticfiles.views.serve() view. This is not suitable for production use! For some common deployment strategies, see Deploying static files.
For example, if your MEDIA_URL is defined as ‘/media/’, you can do this by adding the following snippet to your urls.py:
from django.conf import settings
from django.conf.urls.static import static
urlpatterns = patterns('',
# ... the rest of your URLconf goes here ...
) + static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
福利
当我们在模板(html文件)中引用图片时可以通过下面的方式来轻松获取图片路径:
<img src="{{MEDIA_URL}}/images/logo.png">
参考资料:Django MEDIA_URL and MEDIA_ROOT(http://stackoverflow.com/questions/5517950/django-media-url-and-media-root)
- 【Django】上传图片之路径问题
- 图片上传的路径问题
- j2me 图片上传 路径问题
- django admin图片上传,更改路径和图片名称
- django+apache +linux 图片上传中文问题
- jspSmartUpload上传图片的路径问题
- 关于ckfinder+ckeditor 图片上传路径问题
- django上传图片
- django上传图片
- django上传图片,ImageField
- 【Django】 上传图片
- Django上传图片例子
- Django图片上传。
- django上传图片
- c++ django上传图片
- Django上传图片到七牛云
- 上传图片之样式问题
- 上传图片到服务器系列之----前后台路径获取问题
- LeetCode 题解(186): Palindrome Linked List
- eiqzqfwu
- android(4) 使用ViewPaper 以及这几年来的一些感悟
- 第一次在spark环境下运行jar包
- Recover Rotated Sorted Array
- 【Django】上传图片之路径问题
- PS------裁剪工具的使用
- 用NAN简化Google V8 JS引擎的扩展
- jQuery基础----21jQuery AJAX-异步访问
- jQuery基础----22jQuery AJAX-加载片段
- jQuery基础----23jQuery扩展-jQuery扩展
- jQuery基础----24jQuery扩展-noConflict
- Spring学习笔记-springMVC基于注解的控制器(Demo)
- 寻找志同道合的伙伴