最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 如何在Django中使用图片

    正文概述    2020-08-09   365

    如何在Django中使用图片

    1.首先是html页面的form表单的三大属性,action是提交到哪,method是提交方式,enctype只要有图片上传就要加这个属性

       Django框架自带csrf_token ,所以需要在前端页面也生成csrf_token字符串,来验证真实客户

     <form action="/pic_upload/" method="POST" enctype="multipart/form-data">
              {% csrf_token %}
              <input type="file" name="file">
              <input type="submit" value="提交">
          </form>

    2.如下是上传图片的接口:

    def pic_upload(request):
        if request.method == "GET":
            return render(request,"helloapp/pic_upload.html",locals())
        if request.method == "POST":
            error = ""
            fp = request.FILES.get("file")
            # fp 获取到的上传文件对象
            if fp:
                path = os.path.join(STATICFILES_DIRS[0],'image/' + fp.name)   # 上传文件本地保存路径, image是static文件
                夹下专门存放图片的文件夹
                # fp.name #文件名
                #yield = fp.chunks() # 流式获取文件内容
                # fp.read() # 直接读取文件内容
                if fp.multiple_chunks():    # 判断上传文件大于2.5MB的大文件
                    # 为真
                    file_yield = fp.chunks()    # 迭代写入文件
                    with open(path,'wb') as f:
                        for buf in file_yield:     # for情况执行无误才执行 else
                            f.write(buf)
                        else:
                            print("大文件上传完毕")
                else:
                    with open(path,'wb') as f:
                        f.write(fp.read())
                    print("小文件上传完毕")
                models.ImgPath.objects.create(path=('image/' + fp.name))     #  image是static文件夹下专门存放图片的文件夹
            else:
                error = "文件上传为空"
                return render(request,"helloapp/pic_upload.html",locals())
            return redirect("helloapp/pic_index/") # 重定向到首页

    3.做个图片展示的页面,对图片展示对应的接口传过来的参数加以判断

       {% for img in imgs %}
            <img src="{% static img.path %}">
            {% empty %}
            <h1>您没有上传任何图片</h1>
            {% endfor %}

    4.图片展示的接口:

    def pic_index(request):
        imgs = models.ImgPath.objects.all()
        return render(request,'helloapp/pic_index.html',locals())

    至此,Django中一个简单的图片上传到展示就做好了。


    起源地下载网 » 如何在Django中使用图片

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元