SpringMVC实现文件上传,直接上代码:

后台代码:

01 @RequestMapping(value = "/uploadApk")
02 @ResponseBody
03 public Object uploadApk(
04         @RequestParam(value = "apkFile") MultipartFile apkFile,
05         HttpServletRequest request, HttpServletResponse response) {
06     Map<String,Object> resMap = new HashMap<String,Object>();
07     if (apkFile != null) {
08         //获取保存的路径,
09         String realPath = request.getSession().getServletContext()
10                 .getRealPath("/upload/apk");
11         if (apkFile.isEmpty()) {
12             // 未选择文件
13             resMap.put("status", StatusConstants.STATUS_PARM_IS_EMPTY);
14         } else{
15             // 文件原名称
16             String originFileName = apkFile.getOriginalFilename();
17             try {
18                 //这里使用Apache的FileUtils方法来进行保存
19                 FileUtils.copyInputStreamToFile(apkFile.getInputStream(),
20                         new File(realPath, originFileName));
21                 resMap.put("status",StatusConstants.STATUS_OK);
22             } catch (IOException e) {
23                 System.out.println("文件上传失败");
24                 resMap.put("status", StatusConstants.STATUS_EXECPTION);
25                 e.printStackTrace();
26             }
27         }
28  
29     }
30     return resMap;
31 }

Spring配置文件中需要添加如下内容:

01 <!-- SpringMVC上传文件时,需配置MultipartResolver处理器 -->
02 <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
03     <!-- 指定所上传文件的总大小不能超过80M......注意maxUploadSize属性的限制不是针对单个文件,而是所有文件的容量之和 -->
04     <property name="maxUploadSize" value="80000000"/>
05 </bean>
06   
07 <!-- SpringMVC在超出上传文件限制时,会抛出org.springframework.web.multipart.MaxUploadSizeExceededException -->
08 <!-- 该异常是SpringMVC在检查上传的文件信息时抛出来的,而且此时还没有进入到Controller方法中 -->
09 <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
10     <property name="exceptionMappings">
11         <props>
12             <!-- 遇到MaxUploadSizeExceededException异常时,自动跳转到/WEB-INF/jsp/error_fileupload.jsp页面 -->
13             <prop key="org.springframework.web.multipart.MaxUploadSizeExceededException">error_fileupload</prop>
14         </props>
15     </property>
16 </bean>

jsp页面内容(这里结合的EasyUi的一些内容):

01 function ajaxFileUpload(){
02     //获取软件更新详情
03     var apkIntroduce = $("#apkInfo").val();
04     //开始上传文件时显示一个图片,文件上传完成将图片隐藏
05     //$("#loading").ajaxStart(function(){$(this).show();}).ajaxComplete(function(){$(this).hide();});
06     //执行上传文件操作的函数,使用encodeURI方法,防止传输中文字符的时候出现乱码
07     var uploadUrl = encodeURI(encodeURI(basePath + "uploadApk.do?apkIntroduce="+apkIntroduce));
08     $.ajaxFileUpload({
09         //处理文件上传操作的服务器端地址(可以传参数,已亲测可用)
10         url:uploadUrl,
11 //      url:basePath + "uploadApk.do?apkIntroduce="+apkIntroduce,
12         secureuri:false,                       //是否启用安全提交,默认为false
13         fileElementId:'apkFile',           //文件选择框的id属性
14         dataType:'text',                       //服务器返回的格式,可以是json或xml等
15         success:function(data, status){        //服务器响应成功时的处理函数
16             data = data.replace("<PRE>", '');  //ajaxFileUpload会对服务器响应回来的text内容加上<pre>text</pre>前后缀
17             data = data.replace("</PRE>", '');
18             data = data.replace("<pre>", '');
19             data = data.replace("</pre>", ''); //本例中设定上传文件完毕后,服务端会返回给前台[0`filepath]
20              
21             //将String字符串转换成json
22             var dataset = $.parseJSON(data);
23             if(dataset.status == "ok"){
24                 $('#result').html("Apk上传成功
25 ");
26                 $.messager.alert("提示","上传成功");
27                  
28                 //关闭添加窗口
29                 addApkWindow.window('close');
30                 //刷新页面
31                 datagrid.datagrid('reload');
32                  
33             }else if ( dataset.status == "parm_is_empty"){
34                 $('#result').html("没有选择APK!");
35             }else {
36                 $('#result').html('Apk上传失败,请重试!!');
37             }
38         },
39         error:function(data, status, e){ //服务器响应失败时的处理函数
40             console.log(e);
41             console.log(data);
42             $('#result').html('APK上传失败,请重试!!');
43         }
44     });
45 }

Html页面代码:

01     <div id="addApkWindows">
02      
04         <div id="result"></div>
05 <!--         <img id="uploadImage" src="http://www.firefox.com.cn/favicon.ico"> -->
06         软件更新详情:
07  
08         <textarea rows="2" cols="30" id="apkInfo"></textarea>
09          
10 上传文件:
11  
12         <input type="file" id="apkFile" name="apkFile"/>
13  
14         <input type="button" value="上传" onclick="ajaxFileUpload()"/>
15  
16     </div>

上面的JSP代码中,使用到了JS中的encodeURI方法,这个的目的是为了防止在传递中文参数时的乱码问题,当然,如果只传文件的话,则没有必要使用encodeURI

SpringMVC实现ajax文件上传的更多相关文章

  1. springmvc+ajax文件上传

    环境:JDK6以上,这里我是用JDK8,mysql57,maven项目 框架环境:spring+springmvc+mybaits或spring+springmvc+mybatis plus 前端代码 ...

  2. 使用ajax提交form表单,包括ajax文件上传 转http://www.cnblogs.com/zhuxiaojie/p/4783939.html

    使用ajax提交form表单,包括ajax文件上传 前言 使用ajax请求数据,很多人都会,比如说: $.post(path,{data:data},function(data){ ... },&qu ...

  3. AJAX文件上传实践与分析,带HTML5文件上传API。

    对于HTML5已经支持AJAX文件上传了,但如果需要兼容的话还是得用一点小技巧的,HTML5等等介绍,先来看看以前我们是怎么写的. 网上可能会有一些叫AJAX文件上传插件,但在AJAX2.0之前是不可 ...

  4. 兼容ie的jquery ajax文件上传

    Ajax文件上传插件很多,但兼容性各不一样,许多是对ie不兼容的,另外项目中是要求将网页内容嵌入到桌面端应用的,这样就不允许带flash的上传插件了,如:jquery uploadify...悲剧 对 ...

  5. jQuery插件AjaxFileUpload实现ajax文件上传

    转自:http://www.cnblogs.com/linjiqin/p/3530848.html jQuery插件AjaxFileUpload用来实现ajax文件上传,该插件使用非常简单,接下来写个 ...

  6. ajax 文件上传,ajax

    ajax 文件上传,ajax 啥也不说了,直接上代码! <input type="file" id="file" name="myfile&qu ...

  7. 转: 如何实现jQuery的Ajax文件上传

    [PHP文件上传] 在开始之前,我觉得是有必要把通WEB上传文件的原理简单说一下的.实际上,在这里不管是PHP,JSP,还是ASP处理上传的文件,其实都是WEB早已把文件上传到服务器了,我们只是运用上 ...

  8. [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传

    原文 [代码示例]用Fine Uploader+ASP.NET MVC实现ajax文件上传 Fine Uploader(http://fineuploader.com/)是一个实现 ajax 上传文件 ...

  9. php+ajax文件上传

    php+ajax文件上传 html: <input id="user_real_name" class="input_show" type="t ...

随机推荐

  1. JS实现限行

    一.JS代码实现 1. 机动车辆限行如下图所示: 具体详情请访问:http://www.bjjtgl.gov.cn/zhuanti/10weihao/index.html 2.JS代码实现 <! ...

  2. 51NOD 1424 零树

    Discription 有一棵以1为根的树,他有n个结点,用1到n编号.第i号点有一个值vi. 现在可以对树进行如下操作: 步骤1:在树中选一个连通块,这个连通块必须包含1这个结点. 步骤2:然后对这 ...

  3. Wannafly练习赛14

    B(倍增) 题意:  分析: 先可以用two point预处理出以每个位置为起点的连续段<=k的下一个终点 然后对于每个询问,倍增跳就行了 时间复杂度O(nlogn) C(扫描线处理区间询问) ...

  4. Java中ArrayList类

    ArratList 类:存放同一数据类型容器(只能为引用数据类型,因实际其内部存放的是地址) 1.导入其所在包 import java.util.ArratList 2.创建对象 ArrayList& ...

  5. VC++下编译Libgeotiff(含Libtiff)

    转自原文Win10+VC++下编译Libgeotiff(含Libtiff)详细图文教程 GeoTiff是包含地理信息的一种Tiff格式的文件.Libgeotiff就是一个操作GeoTiff文件的库.同 ...

  6. BroadcastReceiver详解(一)

    今天我们来讲一下Android中BroadcastReceiver的相关知识. BroadcastReceiver也就是“广播接收者”的意思,顾名思义,它就是用来接收来自系统和应用中的广播. 在And ...

  7. flask如何使模板返回大文件,又不消耗大量内存

    当我们要往客户端发送大量的数据,比如一个大文件时,将它保存在内存中再一次性发到客户端开销很大.比较好的方式是使用流,本篇就要介绍怎么在Flask中通过流的方式来将响应内容发送给客户端.此外,我们还会演 ...

  8. oracle学习 第二章 限制性查询和数据的排序 ——03

    这里.我们接着上一小节2.6留下的问题:假设要查询的字符串中含有"_"或"%".又该如何处理呢? 開始今天的学习. 2.7  怎样使用转义(escape)操作符 ...

  9. 如何通过SQL注入获取服务器本地文件

    写在前面的话 SQL注入可以称得上是最臭名昭著的安全漏洞了,而SQL注入漏洞也已经给整个网络世界造成了巨大的破坏.针对SQL漏洞,研究人员也已经开发出了多种不同的利用技术来实施攻击,包括非法访问存储在 ...

  10. HDU 4422 The Little Girl who Picks Mushrooms(数学)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=4422 Problem Description It's yet another festival s ...