Spring   发布时间:2019-10-07  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

Ajax文件下载的实现方法~ 今天菜鸟教程 jb51.cc 分享如何

步骤

1.导入组件并准备静态脚本

false">
 commons-fileupload
 commons-fileupload
 @H_772_11@1.3.2

Ajax 文件上载

@H_675_16@ 
 

1.绑定事件到按钮

false">$("upload").click(ajaxUpload);

2.获取文件

false">var file1 = $("#file1")[0].files[0];
var file2 = $("#file2")[0].files[0];

3.创建内存中的表单对象,并添加向服务器传输的数据

false">//创建内存中的表单对象
var form = new FormData();
//向其中添加要传输的数据
form.append("userfile1", file1);
form.append("userfile2", file2);

4.ajax()上传对象

false">$.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表现层

false">@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文件下载功能,希望对大家有所帮助。程序员遇到问题都会上(菜鸟教程jb51.cc)查找问题解答方法!如果觉得站点还不错,随手转发给程序员朋友一下!

原文链接:http://www.cnblogs.com/chentging/p/7193630.html

大佬总结

以上是大佬教程为你收集整理的利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能全部内容,希望文章能够帮你解决利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签: