前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Django 解决上传文件时,request.FILES为空的问题

Django 解决上传文件时,request.FILES为空的问题

作者头像
砸漏
发布2020-11-02 15:21:47
4.3K0
发布2020-11-02 15:21:47
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

用html的form上传文件时,request.FILES为空,没有收到上传来的文件,但是在request.POST里找到了上传的文件名(只是一个字符串)。

解决方法:

为form表单规定enctype属性,其值为”multipart/form-data”。

enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。

描述

application/x-www-form-urlencoded

在发送前编码所有字符(默认)

multipart/form-data

不对字符编码。在使用包含文件上传控件的表单时,必须使用该值。

text/plain

空格转换为 “+” 加号,但不对特殊字符编码。

<form action=”xxx” method=”xxx” enctype=”multipart/form-data”

这样在request.FILES就能找到上传的文件啦 U*_*U

补充知识:解决Django文件上传views报错NoneType,其他能收到

Django通过form表单给后台提交一个文件的时候,报错

‘NoneType’ object has no attribute ‘name’

前端:

代码语言:javascript
复制
<form accept-charset="UTF-8" action="跳转链接" method="post" 
  <div 
    <input type="file" name="t_photo" accept="image/*" 
  </div 
</form 

后端收不到这个文件,但其他的字符串数据能正常收到。

解决:

1.首先看一下,上传文件的form表单必须加上enctype=”multipart/form-data”,因为默认情况下,编码enctype的值是application/x-www-form-urlencoded,不能用于文件上传,只有使用了multipart/form-data,才能完整的传递文件数据。

代码语言:javascript
复制
<form accept-charset="UTF-8" action="跳转链接" method="post" enctype="multipart/form-data" 
  <div 
    <input type="file" name="t_photo" accept="image/*" 
  </div 
</form 

2.再检查一下,Django的view中接受文件不是在POST里,而是在FILE里。

request.POST.get(‘t_photo’) # 不是在POST里 request.FILES.get(‘t_photo’, None)

以上这篇Django 解决上传文件时,request.FILES为空的问题就是小编分享给大家的全部内容了,希望能给大家一个参考。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档