• jQuery Ajax使用FormData上传文件和其他数据,后端web.py获取


    参考博文:
      Web 前沿——HTML5 Form Data 对象的使用
      通过jQuery Ajax使用FormData对象上传文件


    XMLHttpRequest Level 2 添加了一个新的接口——FormData。与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件。
    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'].file.read()) #文件内容
    

    注意: 1. `
    `的enctype属性需要设置为“multipart/form-data” 2. $.ajax中processData、contentType和cache需要设置为false 3. 后端通过web.input获取文件的字段名,同前端指定的input标签的name属性

    方法二√:不用<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',
    	    type: 'POST',
    	    datatype: 'json',
    	    data: fd,
    	    cache:false,
    	    traditional: true,
    	    contentType: false,
    	    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'].file.read()) #文件内容
    

    注意: 1. 没有``标签(有了也不错) 2. `append()`方法的第二个参数是文件对象,在html中已经通过loadFile方法的参数传过来 3. 后端通过web.input获取文件的字段名,同前端`append()`方法的第一个参数 4. 因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意
  • 相关阅读:
    2021牛客暑期多校训练营3AGuess and lies【dp】
    leetcode 310. Minimum Height Trees 最小高度树(中等)
    leetcode 70. Climbing Stairs 爬楼梯(简单)
    go 结构体嵌套结构体指针,必须先初始化指针结构体,才能赋值
    go 结构体 注意点:go和c一样,所有的运算都应该在函数内进行
    go 模仿go自带的结构体,写go方法
    go 结构体继承,及其方法
    go json序列化与反序列化
    go student mgr 增删改查管理 fmt.Scanf运用
    C#手写页面数据校验类
  • 原文地址:https://www.cnblogs.com/xuehaoyue/p/6978810.html
Copyright © 2020-2023  润新知