Ajax經過FormData上傳文件

<!DOCTYPE>
<html>
<head>
    <meta charset="UTF-8">
    <title> formdata file jquery ajax upload</title>
</head>

<body>
<form id="uploadForm" enctype="multipart/form-data">
    <input id="file" type="file" name="file"/>
    <button id="upload" type="button">upload</button>
</form>

<script src="jquery-1.9.1.min.js"></script>
<script type="text/javascript">
    var btn=$('#upload');
            btn.click(function () {
                $.ajax({
                    url: '/ls/Upfile',
                    type: 'POST',
                    cache: false,// cache設置爲false,上傳文件不須要緩存。
                    data: new FormData($('#uploadForm')[0]),
                    processData: false,//processData設置爲false。由於data值是FormData對象,不須要對數據作處理。
                    contentType: false//  contentType設置爲false,不設置contentType值,由於是由<form>表單構造的FormData對象,且已經聲明瞭屬性enctype="multipart/form-data",因此這裏設置爲false。
                }).done(function(res) {
                    console.log(res)
                }).fail(function(res) {

                })
            }

    );

  /* 
    <form>標籤添加enctype="multipart/form-data"屬性。
    上傳後,服務器端代碼須要使用從查詢參數名爲file獲取文件輸入流對象,由於<input>中聲明的是name="file"。
    從Servlet 3.0 開始,能夠經過 request.getPart() 或 request.getPars() 兩個接口獲取上傳的文件。
    */
</script>
</body>
</html>
相關文章
相關標籤/搜索