Ajax文件下载

利用 FormData 对象和 Spring MVC 配合可以实现Ajax文件上载功能:
步骤
1.导入组件并准备静态脚本
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.2</version> </dependency> <h1>Ajax 文件上载</h1> <input type="file" id="file1"> <br> <input type="file" id="file2"> <br> <input type="button" id="upload" value="上载" > <div id="result"></div>
1.绑定事件到按钮
$("upload").click(ajaxUpload);
2.获取文件
var file1 = $("#file1")[0].files[0];
var file2 = $("#file2")[0].files[0];
3.创建内存中的表单对象,并添加向服务器传输的数据
//创建内存中的表单对象
var form = new FormData();
//向其中添加要传输的数据
form.append("userfile1", file1);
form.append("userfile2", file2);
4.ajax()上传对象
$.ajax({
url:'user/upload.do',//请求地址
data: form, //请求参数
type: 'POST', //请求类型
dataType: 'json',//服务器返回的数据类型
contentType: false,//没有设置任何内容类型头信息
processData: false, //见jQuery_api详解
success: function(obj){ //成功时回调函数,obj表示服务器返回的数据
if(obj.state==0){
$('#result').html("成功!");
}
}
});
5.Spring-MVC表现层
@RequestMapping("/upload.do")
@ResponseBody
public JsonResult upload(
MultipartFile userfile1,
MultipartFile userfile2) throws Exception{
//Spring MVC 中可以利用 MultipartFile
//接收 上载的文件! 文件中的一切数据
//都可以从 MultipartFile 对象中找到
//获取上再是原始文件名
String file1 =
userfile1.getOriginalFilename();
String file2 =
userfile2.getOriginalFilename();
System.out.println(file1);
System.out.println(file2);
//保存文件的3种方法:
//1. transferTo(目标文件)
// 将文件直接保存到目标文件, 可以处理大文件
//2. userfile1.getBytes() 获取文件的全部数据
// 将文件全部读取到内存, 适合处理小文件!!
//3. userfile1.getInputStream()
// 获取上载文件的流, 适合处理大文件
//保存的目标文件夹: /home/soft01/demo
File dir = new File("D:/demo");
dir.mkdir();
File f1 = new File(dir, file1);
File f2 = new File(dir, file2);
//第一种保存文件
//userfile1.transferTo(f1);
//userfile2.transferTo(f2);
//第三种 利用流复制数据
InputStream in1 = userfile1.getInputStream();
FileOutputStream out1 =
new FileOutputStream(f1);
int b;
while((b=in1.read())!=-1){
out1.write(b);
}
in1.close();
out1.close();
InputStream in2 = userfile2.getInputStream();
FileOutputStream out2=
new FileOutputStream(f2);
byte[] buf= new byte[8*1024];
int n;
while((n=in2.read(buf))!=-1){
out2.write(buf, 0, n);
}
in2.close();
out2.close();
return new JsonResult(true);
}
总结
以上所述是小编给大家介绍的利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# ajax文件下载
# formdata
# 对象
# springmvc
# ajax post下载flask文件流以及中文文件名问题
# javascript写一个ajax自动拦截并下载数据代码实例
# SpringMVC+Ajax实现文件批量上传和下载功能实例代码
# Ajax请求二进制流进行处理(ajax异步下载文件)的简单方法
# 基于Blod的ajax进度条下载实现示例代码
# PHP中ajax无刷新上传图片与图片下载功能
# 使用Ajax生成的Excel文件并下载的实例
# jQuery的ajax下载blob文件
# jQuery+Ajax+PHP弹出层异步登录效果(附源码下载)
# PHP+Ajax实现无刷新分页实例详解(附demo源码下载)
# 前端ajax请求+后端java实现的下载zip压缩包功能示例
# 表单
# 小编
# 大文件
# 保存文件
# 在此
# 给大家
# 可以实现
# 种方法
# 可以利用
# 所述
# 绑定
# 回调
# 第一种
# 给我留言
# 感谢大家
# 第三种
# 疑问请
# 有任何
# 上传
# 中找到
相关文章:
常州自助建站工具推荐:低成本搭建与模板选择技巧
浅谈Javascript中的Label语句
免费网站制作appp,免费制作app哪个平台好?
如何快速生成可下载的建站源码工具?
如何配置FTP站点权限与安全设置?
建站之星如何实现网站加密操作?
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
深圳网站制作案例,网页的相关名词有哪些?
官网自助建站平台指南:在线制作、快速建站与模板选择全解析
盘锦网站制作公司,盘锦大洼有多少5G网站?
东莞专业制作网站的公司,东莞大学生网的网址是什么?
如何快速启动建站代理加盟业务?
c++怎么实现高并发下的无锁队列_c++ std::atomic原子变量与CAS操作【详解】
如何快速配置高效服务器建站软件?
如何基于云服务器快速搭建网站及云盘系统?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
如何快速搭建高效WAP手机网站?
创业网站制作流程,创业网站可靠吗?
制作证书网站有哪些,全国城建培训中心证书查询官网?
建站之星如何助力企业快速打造五合一网站?
广州商城建站系统开发成本与周期如何控制?
如何快速完成中国万网建站详细流程?
建站之星安装后界面空白如何解决?
如何制作一个表白网站视频,关于勇敢表白的小标题?
SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?
b2c电商网站制作流程,b2c水平综合的电商平台?
网站制作模板下载什么软件,ppt模板免费下载网站?
网站规划与制作是什么,电子商务网站系统规划的内容及步骤是什么?
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
如何在香港服务器上快速搭建免备案网站?
C++如何使用std::optional?(处理可选值)
如何选购建站域名与空间?自助平台全解析
网站制作网站,深圳做网站哪家比较好?
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南
重庆网站制作公司哪家好,重庆中考招生办官方网站?
用v-html解决Vue.js渲染中html标签不被解析的问题
网站制作知乎推荐,想做自己的网站用什么工具比较好?
建站之星多图banner生成与模板自定义指南
如何快速搭建虚拟主机网站?新手必看指南
焦点电影公司作品,电影焦点结局是什么?
音响网站制作视频教程,隆霸音响官方网站?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
南平网站制作公司,2025年南平市事业单位报名时间?
高端建站如何打造兼具美学与转化的品牌官网?
怎么用手机制作网站链接,dw怎么把手机适应页面变成网页?
如何选择高效便捷的WAP商城建站系统?
高性能网站服务器部署指南:稳定运行与安全配置优化方案
学校免费自助建站系统:智能生成+拖拽设计+多端适配
西安大型网站制作公司,西安招聘网站最好的是哪个?
*请认真填写需求信息,我们会在24小时内与您取得联系。