jQueryAjax使⽤FormData上传⽂件和其他数据后端
web.py获取
XMLHttpRequest Level 2 添加了⼀个新的接⼝——FormData。与普通的 Ajax 相⽐,使⽤ FormData 的最⼤优点就是我们可以异步上传⼆进制⽂件。
java代码查询数据库jQuery 2.0+的版本⽀持FormData
⽅法⼀:使⽤<form>表单初始化FormData对象⽅式上传⽂件
•前端(JQuery):
<form enctype="multipart/form-data">
<input type="file" name="myfile" onchange="loadFile(this.files[0])">
</form>
<script>
function loadFile(file){
var formdata = new FormData($$('form')[0]);
$.ajax({
url: 'jobs/add',
type: 'POST',
datatype: 'json',
data: formdata,
cache:false,
traditional: true,
contentType: false,
processData: false,
success: function (data) {},
error: function () {}
});
}
</script>
•后台(web.py):
class Add:
def POST(self):
i = web.input(myfile={})
print(i['myfile'].filename) #⽂件名
print(i['myfile'].value) #⽂件内容
print(i['myfile'].ad()) #⽂件内容
alops平台
注意:
1.<form>的enctype属性需要设置为“multipart/form-data”
2.$.ajax中processData、contentType和cache需要设置为false
3.后端通过web.input获取⽂件的字段名,同前端指定的input标签的name属性linux命令部署java程序
⽅法⼆√:不⽤<form>,使⽤FormData对象添加字段⽅式上传⽂件
有时,我们并不想⽤
标签,⽽且通过ajax传给后端的并不只有⽂件,可能还有其他的键值对,这时就可以⽤这个⽅法
•前端(JQuery):
<input type="file" onchange="loadFile(this.files[0])" />
function loadFile(file){
container.fd = new FormData();
container.fd.append('myfile',file);
狮驼岭三兄弟恐怖图片container.fd.append('otherkey',othervalue);
$.ajax({
url: 'jobs/add',
jquery下载文件请求type: 'POST',
datatype: 'json',
data: fd,
cache:false,
traditional: true,
contentType: false,java webservice实例
processData: false,
success: function (data) {},
error: function () {}
});
}
•后台(web.py):
class Add:
def POST(self):
i = web.input(myfile={}, otherkey='')
print(i['myfile'].filename) #⽂件名
print(i['myfile'].value) #⽂件内容
print(i['myfile'].ad()) #⽂件内容
注意:
1.没有<form>标签(有了也不错)
2.append()⽅法的第⼆个参数是⽂件对象,在html中已经通过loadFile⽅法的参数传过来
3.后端通过web.input获取⽂件的字段名,同前端append()⽅法的第⼀个参数
4.因为通过web.input获取的值都是字符串,如果除⽂件以外的键值对传过来是null,会⾃动转化为字符串'null'。这点处理的时候需要注意
以上所述是⼩编给⼤家介绍的jQuery Ajax使⽤FormData上传⽂件和其他数据后端web.py获取,希望对⼤家有所帮助,如果⼤家有任何疑问欢迎给我留⾔,⼩编会及时回复⼤家的!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论