<!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>