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'。這點處理的時候需要注意


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM