django 图片上传与显示

由于图片上传的需要,学习了一波上传

1. 上传

前端代码

<form action="写上相应的定向位置" method="post" enctype="multipart/form-data">
    {% csrf_token %}
    <input type="file" id="btn_file" name="pic1" />
    <br/>
    <input type="submit" value="确定" />
</form>

 后台代码

def add_image(request):
    if request.method == "POST":
        picture = request.FILES['pic1']
        fname = '%s\\pictures\\%s' % (settings.MEDIA_ROOT, picture.name)
        with open(fname, 'wb') as pic:
            for c in picture.chunks():
                pic.write(c)
        return HttpResponse("ok")
    else:
        return HttpResponse("error")

 其中有一部分用到了settings中的设置(整个项目的settings)

# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
MEDIA_ROOT = os.path.join(BASE_DIR, "media")

 

这样 图片上传便完成了,效果如下

2.显示图片

我的做法是在数据库中存储相应图片的位置,然后将其显示

但是直观想法便是直接利用路径调用图片,但在django中不可行,因为django关于路径的管理会跳转到url.py中去寻找解决方案

import django.views.static

url(r'^media/pictures/(?P<path>.*)', django.views.static.serve, {'document_root': 'd:/douban/Douban/media/pictures'}),

 

 这样每次遇到media/picture/的路径,他便会到‘document_root’后的值去找,而该值可由setting.py中的BASE_DIR与相对路径构成

 改为

url(r'^media/pictures/(?P<path>.*)', django.views.static.serve, {'document_root': DouBan.settings.BASE_DIR+'/media/pictures'}),

 完成,效果如图

 

转载于:https://www.cnblogs.com/Phoenix-blog/p/8732676.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值