小编给大家分享一下在Django中使用图片的方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

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

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

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

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

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

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

{%forimginimgs%}<imgsrc="{%staticimg.path%}">{%empty%}<h2>您没有上传任何图片</h2>{%endfor%}

4.图片展示的接口:

defpic_index(request):imgs=models.ImgPath.objects.all()returnrender(request,'helloapp/pic_index.html',locals())

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

看完了这篇文章,相信你对在Django中使用图片的方法有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!