Django 解决上传文件时,request.FILES为空的问题
用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'
前端:
<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,才能完整的传递文件数据。
<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为空的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我们。
相关推荐
-
Django实现文件上传下载
本文实例为大家分享了Django实现文件上传下载的具体代码,供大家参考,具体内容如下 一.django实现文件下载 (1).后台接口 如果从服务器直接将文件路径传给浏览器,普通文件可以直接下载,而图片,html,css和pdf格式等文件会直接显示,所以解决办法就是在头文件中让文件流写入硬盘. ①.最简单的文件下载功能的实现,直接将文件流放入HttpResponse对象即可 def file_download(request): # do something... with open('file_
-
Django实现文件上传下载功能
项目介绍 最近学习django,通过文件上传下载这个小项目,总结下常用的知识点. 做这个案例我有以下需求: 1.要支持一次上传多个文件 2.支持上传后记录上传的数据以及列表展示 3.支持下载和删除文件记录 效果展示 数据库记录 开发步骤 创建项目: django-admin startproject file_upload cd file_upload python manage.py startapp uploader 目录结构: 0.settings.py LANGUAGE_CODE = '
-
django框架实现一次性上传多个文件功能示例【批量上传】
本文实例讲述了django框架实现一次性上传多个文件功能.分享给大家供大家参考,具体如下: 在用django 写文件上传的时候,从request.FILES['myfiles'] 获取到的文件始终只有一个, 但在HTML页面上明明用 HTML5 的 文件控件选择了多个文件,用的是CHROME 浏览器,一次可以选择多个文件上传.在 Pydev 开启debug模式,查看request 对象,发现上传的多个文件确实在request对象中,但为什么 用request.FILES['myfiles']
-
Python request使用方法及问题总结
一.总结说明 模拟postman访问接口,具体参照七.python接口开发(二)>>三.postman访问接口,本篇文章调用的接口,也是来自于接口开发的源码,阅读本篇文章最好先看下python接口是怎样开发的 模拟get方式访问:res = requests.get(url,params=data,headers = headers) 第一种方式:res = requests.get(url, params=data, headers = headers) 第二种方式:res = reques
-
Django 解决上传文件时,request.FILES为空的问题
用html的form上传文件时,request.FILES为空,没有收到上传来的文件,但是在request.POST里找到了上传的文件名(只是一个字符串). 解决方法: 为form表单规定enctype属性,其值为"multipart/form-data". enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码. 值 描述 application/x-www-form-urlencoded 在发送前编码所有字符(默认) multipart/form-data 不对字符编
-
JavaScript上传文件时不用刷新页面方法总结(推荐)
用js给出一个上传文件时不用刷新页面的方案 <input id="upload" type="file"/> <button id="upload-btn">upload</button> document.getElementById('upload-btn').onclick = function(){ var oInput = document.getElementById('upload'); var
-
Django Admin 上传文件到七牛云的示例代码
中文圈关于Django Admin 上传文件到七牛云的资料和函数库已经是2年前的了,国外的则都是关于AWS S3.Azure Storage一些国外的服务的.我根据Django的文档里提到的存储系统来实现上传文件到七牛云的简单功能. 在Django Admin的表单是根据数据模型生成的,其中文件上传由FileField和继承FileField的ImageField来决定的,文件上传到静态文件目录,数据库保存相对路径.实现上传文件到七牛云我们是根据FileField的storage参数来实现的.
-
Springboot上传文件时提示405问题及排坑过程
目录 Springboot上传文件时提示405 解决方案1 解决方案2 Springboot使用过程中遇到的一些问题 异常一 异常二:Mysql连接报错 异常三:整合Druid密码解密失败 Springboot上传文件时提示405 问题描述:上传文件时请求不通,状态码返回405,如下图: 问题分析:405 Method Not Allowed,请求行中指定的请求方法不能被用于请求相应的资源.该响应必须返回一个Allow 头信息用以表示出当前资源能够接受的请求方法的列表.简单说就是请求方法不支持
-
PHP上传文件时自动分配路径的方法
本文实例讲述了PHP上传文件时自动分配路径的方法.分享给大家供大家参考.具体分析如下: 网站上传文件时,如果是小的企业站,放在一个目录还没问题,当网站大了,上传的文件多了,我们就不能放在同一个目录了,这里我们就来讲讲用PHP自动给上传的文件分配路径的方法. PHP分配上传文件的路径实例 主要程序片段如下: 复制代码 代码如下: <?php /*数字方式分配路径*/ function allotPath($id, $extend='jpg') { $folders = st
-
解决springboot项目上传文件出现临时文件目录为空的问题
最近写文件上传到服务器读取的代码,前端使用FormData上传,服务端用MultipartFile接收,自己测试了下MultipartFile对象有什么东西,结果一般属性都能出来,测试getInputStrea()方法的时候出现了以下错误,简单一看这是什么目录,从来没见过啊: 百度一番之后发现了这是临时文件存放的路径,不清楚根据什么去放在这个目录的,但是这个目录本机的确没有,linux系统下好像系统会10天清空一次,翻阅了API底下有这个 百度的时候也发现另外一个坑,spring配置的MaxIn
-
PHP上传文件时文件过大$_FILES为空的解决方法
在做图片上传的时候突然发现一张gif图片上传失败 size为0,实际大小为4.66M.上传小文件时可以,传大文件就不行,看了下PHP.INI里面upload_max_filesize = 2M, 问题就出在这了,修改其值 复制代码 代码如下: ; Maximum allowed size for uploaded files. upload_max_filesize = 20M 重启了下nginx问题解决.
-
整合ckeditor+ckfinder,解决上传文件路径问题
这三种情况下所得到的server.MapPath是一致的,这就导致上传之后写入数据库的图片地址和实际图片存储地址不一致,因此,我们需要自定义一个路径地址userDir,让baseUrl只管写入数据库的图片地址,而创建的新目录baseDir为另外一个....这样不管你的网站通过怎样的方式访问都是OK的,这个问题郁闷了很久才解决 asp的config.asp修改如下: Dim baseUrl, baseDir, userDir baseUrl = "../ckfinder/userfiles/&qu
-
vue上传文件formData入参为空,接口请求500的解决
目录 1.首先封装axios请求 2.vue文件点击上传按钮 接下来贴出解决的方案 long long long time no see,最近遇到个奇葩的问题来记录下,不知道有没有小伙伴和我一样崩溃过. 写了三年代码,上传这么简单的功能.第一次遇到前端入参fromData请求接口报500的问题,百度了好多资料尝试也没有解决.后台一直说我前端的问题,于是debugger一步一步查. 下面来看看报错代码的流程,用你们的丰富经验和火眼金睛帮忙看下到底错在哪里了?! 本项目用的是vue-cli3脚手架搭
-
ASP.NET在上传文件时对文件类型的高级判断的代码
复制代码 代码如下: using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.UI.WebControls.WebParts; using Syste
随机推荐
- MySQL 语句注释方式简介
- javascript ie6兼容position:fixed实现思路
- 监控服务器swap并重启php的Shell脚本
- vue轮播图插件vue-awesome-swiper的使用代码实例
- 如何抽象一个Vue公共组件
- JavaScript中闭包的详解
- Win2008下载 中文版、英文版官方下载地址
- Centos5给/根分区扩容
- iOS实现从背景图中取色的代码
- iOS开发之UIScrollView详解
- ASP.Net下载大文件的实现方法
- JavaScript中点击事件的写法
- 跟老齐学Python之玩转字符串(2)更新篇
- Android中的SQL查询语句LIKE绑定参数问题解决办法(sqlite数据库)
- Android中应用界面主题Theme使用方法和页面定时跳转应用
- IE hack条件写法
- java留言管理系统中模糊查询实例分享
- 解决C#中Linq GroupBy 和OrderBy失效的方法
- rsync 同步错误 cwrsync rsync error rsync error: some files/attrs were not transferred 解决方法
- JavaScript 中的日期和时间及表示标准介绍