利用 FormData 对象和 Spring MVC 配合实现Ajax文件下载功能
程序员文章站
2022-06-22 13:07:44
ajax文件下载
利用 formdata 对象和 spring mvc 配合可以实现ajax文件上载功能:
步骤
1.导入组件并准备静态脚本
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文件下载功能,希望对大家有所帮助