## 场景一
提交一般参数
~~~
<form id= "uploadForm" action= "http://localhost:8080/cfJAX_RS/rest/file/upload" method= "post" enctype ="multipart/form-data">
<h1 >测试通过Rest接口上传文件 </h1>
<p >指定文件名: <input type ="text" name="filename" /></p>
<p >上传文件: <input type ="file" name="file" /></p>
<p >关键字1: <input type ="text" name="keyword" /></p>
<p >关键字2: <input type ="text" name="keyword" /></p>
<p >关键字3: <input type ="text" name="keyword" /></p>
<input type ="submit" value="上传"/>
</form>
<script type="text/javascript">
$.ajax({
url : "http://youractionurl",
type : "POST",
data : $( '#uploadForm').serialize(),
success : function(data) {
$( '#serverResponse').html(data);
},
error : function(data) {
$( '#serverResponse').html(data.status + " : " + data.statusText + " : " + data.responseText);
}
});
</script>
~~~
## 场景二
如上,通过$('#postForm').serialize()可以对form表单进行序列化,从而将form表单中的所有参数传递到服务端。
但是上述方式,只能传递一般的参数,上传文件的文件流是无法被序列化并传递的。如今主流浏览器都开始支持一个叫做FormData的对象,通过FormData对象,可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单",这样我们就可以轻松地实现文件上传了。
~~~
<form id="uploadForm" enctype="multipart/form-data" method="post" name="fileinfo">
<input id="file" type="file"/>
<button id="upload" type="button">upload</button>
</div>
<script type="text/javascript">
var oData = new FormData(document.forms.namedItem("fileinfo" ));
oData.append('file', $('#file')[0].files[0]);
var oReq = new XMLHttpRequest();
oReq.open( "POST", "/upload.php" , true );
oReq.onload = function(oEvent) {
if (oReq.status == 200) {
oOutput.innerHTML = "Uploaded!" ;
} else {
oOutput.innerHTML = "Error " + oReq.status + " occurred uploading your file.<br \/>";
}
};
oReq.send(oData);
</script>
~~~
## 场景三
上面的例子中,我们看到上传文件部分是使用底层的XMLHttpRequest对象发送上传请求,那么怎么通过jQuery的Ajax上传呢?
接下来将介绍通过jQuery使用FormData对象上传文件。
#### 方法一:使用`<form>`表单初始化FormData对象方式上传文件
~~~
<form id="uploadForm" enctype="multipart/form-data">
<input id="file" type="file" name="file"/>
<button id="upload" type="button" onclick="doUpload()">upload</button>
</form>
<script type="text/javascript">
function doUpload() {
var formData = new FormData($( "#uploadForm" )[0]);
$.ajax({
url: '/upload',
type: 'POST',
dataType: Json,
data: formData,
async: false,
cache: false,
contentType: false,
processData: false,
success: function (returndata) {
alert(returndata);
},
error: function (returndata) {
alert(returndata);
}
});
}
</script>
~~~
这里要注意几点:
* processData设置为false。因为data值是FormData对象,不需要对数据做处理。
* `<form>`标签添加enctype="multipart/form-data"属性。
* cache设置为false,上传文件不需要缓存。
* contentType设置为false。因为是由`<form>`表单构造的FormData对象,且已经声明了属性enctype="multipart/form-data",所以这里设置为false。
* 上传后,服务器端代码需要使用从查询参数名为file获取文件输入流对象,因为<input>中声明的是name="file"。
#### 方法二:使用FormData对象添加字段方式上传文件
~~~
<div id="uploadForm">
<input id="file" type="file"/>
<button id="upload" type="button" onclick="doUpload()">upload</button>
</div>
~~~
这里没有`<form>`标签,也没有enctype="multipart/form-data"属性。
~~~
<script type="text/javascript">
function doUpload() {
var formData = new FormData();
formData.append('file', $('#file')[0].files[0]);
$.ajax({
url: '/upload',
type: 'POST',
dataType: Json,
data: formData,
async: false,
cache: false,
contentType: false,
processData: false
}).done(function(res) {
}).fail(function(res) {});
}
</script>
~~~
这里和方法一有几处不一样:
* append()的第二个参数应是文件对象,即$('#file')[0].files[0]。
* contentType也要设置为‘false’。
* 从代码$('#file')[0].files[0]中可以看到一个`<input type="file">`标签能够上传多个文件,只需要在`<input type="file">`里添加multiple或multiple="multiple"属性。
- JavaScript笔记
- JQuery
- Echarts初级入门
- Js常用正则表达式
- 使用vuejs前端框架
- Bootbox.js官方文档中文版
- LocalStorage基本用法小结
- Toastr消息提示插件中文文档
- Ajax提交Form数据及文件上传
- Nodejs笔记
- Python笔记
- Scrapy爬虫技术
- Django框架
- Java笔记
- 环境搭建
- Php笔记
- MacOS 10.13.6搭建PHP开发环境
- Php常见问题及解决方法
- 玩转laravel之homestead
- Apache服务器的基本操作
- 如何使用CentOS7 + Lnmp
- ThinkPHP爬坑之路
- 初识Swoole
- 小贴士
- 习题集
- 方法集
- 数据库
- mysql
- 常用的SQL语句
- 日常操作和设置
- 常见问题及解决办法
- 读写分离和主从复制
- 数据表分区
- postgresql
- 在PHP中的应用
- redis
- 测试
- 接口测试
- Web测试
- 杂项
- Sublime text3使用小贴士
- 利用虚拟机学习Linux
- PHPstorm常用设置
- Windows实用tips
- 微信开发小知识
- Git常用操作
- Swift入门
- 机器学习
- 系统命令
- 网络拾贝