`
changhongbao
  • 浏览: 124021 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

SpringMVC结合ajaxfileupload文件无刷新上传

 
阅读更多

jQuery没有提供ajax的文件上传,我们可以通过ajaxfileupload实现ajax文件的上传。其实ajaxfileupload文件上传特别的简单。下面就演示一下在SpringMVC中实现ajax的文件上传。

      1、后台接收代码

     首先在spring的配置文件中添加文件上传配置

     

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1.      <!-- 文件上传 -->  
  2. lt;bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">  
  3. <property name="defaultEncoding" value="UTF-8"/>    
  4. lt;/bean>  

 

    再写文件接收的代码

       

[java] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. package org.andy.controller;  
  2.   
  3. import java.io.File;  
  4. import java.io.IOException;  
  5. import java.util.Arrays;  
  6. import java.util.Date;  
  7. import java.util.HashMap;  
  8.   
  9. import javax.servlet.ServletContext;  
  10. import javax.servlet.http.HttpServletRequest;  
  11. import javax.servlet.http.HttpServletResponse;  
  12.   
  13. import org.apache.commons.fileupload.servlet.ServletFileUpload;  
  14. import org.apache.log4j.Logger;  
  15. import org.springframework.stereotype.Controller;  
  16. import org.springframework.web.bind.annotation.RequestMapping;  
  17. import org.springframework.web.bind.annotation.RequestMethod;  
  18. import org.springframework.web.bind.annotation.RequestParam;  
  19. import org.springframework.web.multipart.commons.CommonsMultipartFile;  
  20.   
  21.   
  22. @Controller  
  23. @RequestMapping("/upload")  
  24. public class UploadController {  
  25.   
  26.     private static final Logger LOG = Logger.getLogger(UploadController.class);  
  27.   
  28.     private static final HashMap<String, String> TypeMap = new HashMap<String, String>();  
  29.   
  30.     static {  
  31.         TypeMap.put("image""gif,jpg,jpeg,png,bmp");  
  32.         TypeMap.put("flash""swf,flv");  
  33.         TypeMap.put("media""swf,flv,mp3,wav,wma,wmv,mid,avi,mpg,asf,rm,rmvb");  
  34.         TypeMap.put("file""doc,docx,xls,xlsx,ppt,pptx,htm,html,txt,dwg,pdf");  
  35.     }  
  36.   
  37.     /** 
  38.      * 文件上传 之 图片上传 
  39.      *  
  40.      * @param file 
  41.      * @param request 
  42.      * @return message: -1 没有文件上传 0 上传成功 1 上传失败 2 文件超过上传大小 3 文件格式错误 4 上传文件路径非法 5 上传目录没有写权限 
  43.      *        
  44.      *  
  45.      */  
  46.     @RequestMapping(value = "/imageUpload", method = RequestMethod.POST)  
  47.     public void imageUpload(  
  48.             @RequestParam("file") CommonsMultipartFile file,  
  49.             @RequestParam(required = false) String filePre, HttpServletRequest request, HttpServletResponse response) {  
  50.         LOG.info("file name is :" + file.getOriginalFilename());  
  51.           
  52.         if (!file.isEmpty()) {  
  53.             ServletContext servletContext = request.getSession()  
  54.                     .getServletContext();  
  55.             String uploadPath = servletContext.getRealPath("/")  
  56.                     + "uploadImage/";  
  57.             // 文件上传大小  
  58.             long fileSize = 3 * 1024 * 1024;  
  59.   
  60.             if (file.getSize() > fileSize) {  
  61.                 backInfo(response, false2"");  
  62.                 return;  
  63.             }  
  64.   
  65.             String OriginalFilename = file.getOriginalFilename();  
  66.   
  67.             String fileSuffix = OriginalFilename.substring(  
  68.                     OriginalFilename.lastIndexOf(".") + 1).toLowerCase();  
  69.             if (!Arrays.asList(TypeMap.get("image").split(",")).contains(  
  70.                     fileSuffix)) {  
  71.                 backInfo(response, false3"");  
  72.                 return;  
  73.             }  
  74.   
  75.             if (!ServletFileUpload.isMultipartContent(request)) {  
  76.                 backInfo(response, false, -1"");  
  77.                 return;  
  78.             }  
  79.   
  80.             // 检查上传文件的目录  
  81.             File uploadDir = new File(uploadPath);  
  82.             if (!uploadDir.isDirectory()) {  
  83.                 if (!uploadDir.mkdir()) {  
  84.                     backInfo(response, false4"");  
  85.                     return;  
  86.                 }  
  87.             }  
  88.   
  89.             // 是否有上传的权限  
  90.             if (!uploadDir.canWrite()) {  
  91.                 backInfo(response, false5"");  
  92.                 return;  
  93.             }  
  94.               
  95.             //新文件名  
  96.             String newname = "";  
  97.             if(null != filePre){  
  98.                 newname += filePre;//对应模块上传的文件名前缀  
  99.             }  
  100.               
  101.              newname += DateFormater.format(new Date(),  
  102.                     DateFormater.DATETIME_PATTERN) + "." + fileSuffix;  
  103.   
  104.             File saveFile = new File(uploadPath, newname);  
  105.   
  106.             try {  
  107.                 file.transferTo(saveFile);  
  108.                 backInfo(response, true0, newname);  
  109.             } catch (Exception e) {  
  110.                 LOG.error(e.getMessage(), e);  
  111.                 backInfo(response, false1"");  
  112.                 return;  
  113.             }  
  114.         } else {  
  115.             backInfo(response, false, -1"");  
  116.             return;  
  117.         }  
  118.   
  119.     }  
  120.   
  121.     // 返回信息  
  122.     private void backInfo(HttpServletResponse response, boolean flag, int message,  
  123.             String fileName) {  
  124.         String json  = "";  
  125.         if (flag) {  
  126.             json = "{ \"status\": \"success";   
  127.         } else {  
  128.             json = "{ \"status\": \"error";   
  129.         }  
  130.         json += "\",\"fileName\": \"" + fileName + "\",\"message\": \"" + message + "\"}";  
  131.         try {  
  132.             response.setContentType("text/html;charset=utf-8");  
  133.             response.getWriter().write(json);  
  134.         } catch (IOException e) {  
  135.             LOG.error(e.getMessage(), e);  
  136.         }  
  137.     }  
  138.   
  139. }  



 

 

         2、前台接受代码

          使用ajaxfileupload时,首先下载ajaxfileupload文件,导入对应的js文件

    

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. <script type="text/javascript" src="js/ajaxfileupload.js"></script>  

 

 

       文件传输字段必须为file类型,如下:

 

[html] view plain copy
 在CODE上查看代码片派生到我的代码片
  1. <input type="file" id="file" name="file" onchange="ajaxFileUpload();"/>  


      其次,处理上传文件:

 

           

[javascript] view plain copy
 在CODE上查看代码片派生到我的代码片
  1.          //ajax 实现文件上传   
  2. unction ajaxFileUpload() {  
  3.   
  4. $.ajaxFileUpload({  
  5.     url : "upload/imageUpload.shtml",  
  6.     secureuri : false,  
  7.     data : {  
  8.         filePre : "feedback",  
  9.         p : new Date()  
  10.     },  
  11.     fileElementId : "file",  
  12.     dataType : "json",  
  13.     success : function(data) {  
  14.         if (data.status == "success") {  
  15.             //上传成功  
  16.         }  
  17.         switch(data.message){  
  18.          //解析上传状态  
  19.             case "0" : //上传成功  
  20.                        break;  
  21.             case "-1" : //上传文件不能为空  
  22.                       break;  
  23.             default//上传失败  
  24.                  break;  
  25.         }  
  26.     },  
  27.     error : function(data) {  
  28.         //上传失败  
  29.     }  
  30. });  


本文出处:http://blog.csdn.net/fengshizty

 

其实很简单。

分享到:
评论

相关推荐

    SpringMVC结合ajaxfileupload.js实现文件无刷新上传

    总结起来,结合SpringMVC和ajaxfileupload.js实现文件无刷新上传,需要在前后端进行相应的配置和代码编写。前端利用ajaxfileupload.js处理文件选择和异步上传,后端通过SpringMVC Controller接收并处理文件。这种...

    WEB文件上传之SpringMVC+ajaxfileupload使用(三)

    综上所述,SpringMVC与AJAXFileUpload的结合使用,可以实现高效且用户体验良好的文件上传功能。在实际开发中,我们需要关注前后端的交互细节,同时确保安全性与性能。在项目中,`upload`目录可能包含了相关的示例...

    SpringMVC结合ajaxfileupload实现文件无刷新上传代码

    【SpringMVC结合ajaxfileupload实现文件无刷新上传】 在现代Web开发中,用户期望有更流畅、更快捷的交互体验,文件上传功能也不例外。传统的文件上传方式通常需要页面刷新,而通过Ajax技术,我们可以实现在不刷新...

    SpringMVC文件上传,多文件上传实例

    在这个“SpringMVC文件上传,多文件上传实例”中,我们将深入探讨如何在SpringMVC环境中实现文件上传功能,包括单个文件上传以及多个文件的批量上传。 1. **文件上传原理**: 文件上传是通过HTTP协议的POST请求来...

    springMvc单文件多文件上传

    springMvc 文件上传,springMvc 支持单文件和多文件上传,

    SpringMVC+Ajax异步文件上传

    在本教程中,我们将探讨如何结合`SpringMVC`和`Ajax`来实现异步文件上传,并讨论短视频背景以及`a`标签绑定文件域的相关知识。 1. **SpringMVC中的文件上传** - **MultipartFile接口**:`SpringMVC`提供了一个名为...

    ajaxFileUpload+springMvc上传文件

    总结来说,结合`ajaxFileUpload.js`和`Spring MVC`,我们可以轻松地在Web应用中实现无刷新的文件上传功能。这种方式既提高了用户体验,又充分利用了Spring MVC的灵活性和强大的功能。记得在实际开发中,根据项目需求...

    springMVC上传文件.zip_springmvc_上传文件_文件上传

    下面将详细阐述如何在SpringMVC中进行文件上传,并涵盖相关知识点。 1. **MultipartFile接口** SpringMVC提供了一个名为`MultipartFile`的接口,用于处理多部分表单数据中的文件部分。这个接口提供了获取文件名、...

    springMVC 上传文件方式

    springMVC 上传文件方式springMVC 上传文件方式springMVC 上传文件方式

    IDEA SpringMVC 实现文件的上传下载

    在SpringMVC框架中,实现文件的上传与下载是常见的需求。IntelliJ IDEA作为流行的Java开发集成环境,为开发者提供了高效便捷的开发体验。在这个项目中,我们使用IDEA来构建一个基于SpringMVC的系统,实现了文件的...

    SpringMVC框架实现文件的上传和下载

    在SpringMVC框架中,文件的上传和下载是常见的功能需求,主要用于处理用户的数据交互,例如用户上传图片、文档等,或者系统提供文件下载服务。本文将深入探讨如何使用SpringMVC来实现这一功能。 首先,我们需要理解...

    SpringMVC单文件上传、多文件上传、文件列表显示、文件下载

    以下将详细讲解SpringMVC如何实现单文件上传、多文件上传、文件列表显示以及文件下载。 1. **单文件上传** 在SpringMVC中,我们可以使用`@RequestParam("file") MultipartFile file`注解来接收前端提交的单个文件...

    Spring下的子框架SpringMVC实现单个文件上传功能

    ### SpringMVC 实现单个文件上传功能 #### 一、背景介绍 在现代Web应用开发中,文件上传是一项常见的需求。SpringMVC作为Spring框架的一部分,提供了强大的支持来处理文件上传任务。本文将详细介绍如何在SpringMVC...

    springmvc框架的文件上传 下载

    在这个项目"springmvc框架的文件上传 下载"中,你可能会遇到如404错误等常见问题,下面将详细介绍SpringMVC中文件上传和下载的实现及其可能遇到的问题。 **文件上传** 1. **配置**: 首先,你需要在`dispatcher-...

    SpringMVC上传文件 SSH上传文件

    本主题将深入探讨如何使用SpringMVC和SSH(Struts2 + Hibernate + Spring)框架来实现文件的上传与下载。 首先,我们来看SpringMVC中的文件上传。SpringMVC是Spring框架的一部分,它提供了强大的MVC设计模式支持,...

    JavaEE企业级开发-----SpringMVC实现 文件的上传下载实验报告.docx

    在JavaEE企业级开发中,SpringMVC框架是广泛用于构建Web应用程序的工具,它提供了丰富的功能,包括处理文件上传和下载。本实验报告将详细阐述如何利用SpringMVC实现文件上传与下载的功能。 首先,文件上传的核心...

    基于springmvc实现文件上传下载 基于AOP的日志功能

    基于springmvc实现文件上传下载 基于AOP的日志功能基于springmvc实现文件上传下载 基于AOP的日志功能基于springmvc实现文件上传下载 基于AOP的日志功能基于springmvc实现文件上传下载 基于AOP的日志功能基于...

    ajaxfileupload+springmvc例子

    本文将详细介绍如何结合 `AjaxFileUpload` 和 `SpringMVC` 实现文件上传。 ### 1. 引入库和配置 首先,确保在项目中引入了jQuery库以及`AjaxFileUpload.js`。在JSP页面中,可以使用以下代码引入这些文件: ```...

Global site tag (gtag.js) - Google Analytics