• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Django实现图片上传功能步骤解析

python 搞代码 4年前 (2022-01-08) 33次浏览 已收录 0个评论

这篇文章主要介绍了Django实现图片上传功能步骤解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

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

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

      {% csrf_token %}          

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 %}  {% empty %} <h1>您没有上传任何图片</h1> {% endfor %}

4.图片展示的接口:

 def pic_index(req<strong style="color:transparent">来源gaodaima#com搞(代@码网</strong>uest): imgs = models.ImgPath.objects.all() return render(request,'helloapp/pic_index.html',locals())

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

以上就是Django实现图片上传功能步骤解析的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Django实现图片上传功能步骤解析

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址