`
wuce7758
  • 浏览: 184062 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论
  • YTT1121: 有网络拓扑发现的源代码么?能不能发我一份学习一下,现在我正要做 ...
    java拓扑图
  • YTT1121: 大神,有网络拓扑发现的源代码么?或者您会编写么?我需要做科研改 ...
    java拓扑图
  • YTT1121: 大神,有网络拓扑发现的源代码么?或者您会编写么?我需要做科研改 ...
    java拓扑图
  • poettang: 求代码分享学习,谢谢!膜拜大神!258026921@qq.co ...
    java拓扑图
  • oiqio: 87836238@qq.com,感谢楼主,来一份~
    java拓扑图

使用spring对commons fileUpload的包装

阅读更多

巧妙使用spring对commons fileUpload的包装
         以前简单使用过spring的文件上传,当时没深入研究,以为spring只能实现单个文件的上传,所以后来就又大致学了下commons fileupload组件。在最近的工作中,有同事提出,他在把commons fileupload组件集成到spring中时总是出错,然后我大致看了一下,发现是spring DispatcherServlet的缘故。然后google了一下,发现sping本身就包装了commons fileupload,并且很好用。汗颜!为自己以前无知的写那篇《利用Jakarta commons fileupload组件实现多文件上传》汗颜!唉,都是自己以前不读书不看报的结果啊,呵呵:)

一.前台页面        

         我们的目标是要实现多文件上传,并且预先我并不知道客户要上传多少个文件。我们先写个jsp页面吧,要实现可以动态控制上传多少文件,基本代码如下:

        <form method="post" action="./upload.do" enctype="multipart/form-data">
            <div id="uploadDiv">
                <input type="file" name="file1" />
            </div>
            <input type="button" value="继续上传" onclick="javascript:btn_click();">
            <input type="hidden" id="fileCount" name="fileCount" value="1">
            <input type="submit" value="上传" />
        </form>恩,要实现动态控制上传文件个数,我们需要使用伟大的javascript了

 function btn_click()...{
  var fileNo=Number(document.getElementById('fileCount').value)+1;
  newDiv=document.createElement("div")
  newDiv.id="divFile"+fileNo;
  document.getElementById('uploadDiv').appendChild(newDiv)
  document.getElementById('fileCount').value=fileNo;
  newDiv.innerHTML="<input type='file' name='file"+fileNo+"'>";
 }ok,现在我们的界面如下:http://dl2.csdn.net/down4/20070710/10163733412.JPG

二.后台实现   

  1. 好了,前台我们搞定了,现在考虑一下后台处理吧。我写了一个Command Bean,非常简单,如下:

public class FUploadBean ...{
 private byte[] file;
 public byte[] getFile() ...{
  return file;
 }
 public void setFile(byte[] file) ...{
  this.file = file;
 }
} 在spring Web MVC模式中,必须定义一个Command对象,将其和Form表单绑定。这个command class需要在spring上下文中进行配置,可以作为controller的property进行配置。呆会会在配置文件中看到相关配置。

2. 然后就是一个Controller

public class FUploadController extends SimpleFormController ...{

 public ModelAndView onSubmit(HttpServletRequest request,
   HttpServletResponse res, Object obj, BindException errors)
   throws Exception ...{

  MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;

  int fileCount = Integer.parseInt(request.getParameter("fileCount"));

  for (int i = 1; i <= fileCount; i++) ...{
   CommonsMultipartFile cFile = (CommonsMultipartFile) multipartRequest.getFile("file" + i);
   File uploadedFile = new File("E:/upload" + "/"+ cFile.getOriginalFilename());
   FileCopyUtils.copy(cFile.getBytes(), uploadedFile);
  }

  return null;
 }

 // 注册一个spring的编辑器非常重要,没有这个方法,上传将不能进行
 protected void initBinder(HttpServletRequest request,
   ServletRequestDataBinder binder) throws ServletException ...{
  binder.registerCustomEditor(byte[].class,
    new ByteArrayMultipartFileEditor());
 }
}
注意:必须定义initBinder方法。

三.配置文件

接下来就是配置文件了,熟悉spring的人应该很容易看懂了。

1.web.xml

    <servlet>
        <servlet-name>springStudy</servlet-name>
        <servlet-class>
            org.springframework.web.servlet.DispatcherServlet
        </servlet-class>
        <load-on-startup>1</load-on-startup>
    </servlet>
    <servlet-mapping>
        <servlet-name>springStudy</servlet-name>
        <url-pattern>*.do</url-pattern>
    </servlet-mapping>2.springStudy-servlet.xml

    <bean id="multipartResolver"
        class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
        <property name="maxUploadSize" value="50000000" />
        <property name="defaultEncoding" value="utf-8" />
    </bean>

    <bean id="urlMapping"
        class="org.springframework.web.servlet.handler.SimpleUrlHandlerMapping">
        <property name="mappings">
            <props>
                <prop key="/upload.do">uploadServlet</prop>
            </props>
        </property>
    </bean>
    <bean id="uploadServlet"
        class="chb.spring.study.web.FUploadController">
        <property name="commandClass"
            value="chb.spring.study.web.FUploadBean" />
    </bean>注:需要注意的是,在spring中要实现文件上传,必须在spring的上下文中定义MultipartResolver,这样spring在发现该表单请求是mutipart时,就会使用spring定义的解析器去解析。这里我们使用的是
CommonsMultipartResolver,也就是会转化为commons fileupload。CommonsMultipartResolver继承自CommonsFileUploadSupport,而CommonsFileUploadSupport是对commons fileupload组件的包装,所以我们可以在定义multipartResolver时设置相关参数,比如最大允许上传文件数,字符编码等。这里设置<property name="defaultEncoding" value="utf-8" />就是为了解决中文问题。

 

分享到:
评论

相关推荐

    一个简单的使用commons-fileupload包上传文件的例子

    本示例将详细介绍如何使用`commons-fileupload`和`commons-io`这两个库来实现一个简单的文件上传功能。 首先,我们需要引入`commons-fileupload`和`commons-io`的依赖。在Maven项目中,可以在`pom.xml`文件中添加...

    commons fileupload

    使用Commons FileUpload,开发者可以轻松地处理多个文件上传,同时检查文件大小,限制上传类型,以及进行错误处理。这个组件支持流式处理,这意味着它不需要一次性将整个文件加载到内存中,这对于处理大文件至关重要...

    commons-fileupload-1.3.1.jar

    在实际应用中,结合Servlet或Spring MVC等框架,可以轻松地集成Apache Commons FileUpload,处理用户的文件上传请求,从而构建安全、可靠的文件上传功能。同时,这个库也支持自定义策略,如文件存储路径、临时文件...

    commons-fileupload及源码

    2. **分割多部分数据**:FileUpload使用`DiskFileItemFactory`来创建`FileItem`对象,每个`FileItem`代表请求中的一部分数据,可以是文本字段或上传的文件。 3. **内存与磁盘管理**:`DiskFileItemFactory`提供了一...

    commons-fileupload-1.3.2.jar

    在本文中,我们将深入探讨Apache Commons FileUpload库的核心功能、特性以及如何在实际项目中使用它。 Apache Commons FileUpload库解决了Java Web应用中一个常见问题:处理通过表单提交的大文件。在HTTP协议中,...

    commons-fileupload-1.3.3.jar和commons-io-2.6.jar

    在Java开发中,上传文件是一项常见的任务,而`commons-fileupload-1.3.3.jar`和`commons-io-2.6.jar`是Apache Commons项目中的两个重要库,专门用于处理HTTP请求中的文件上传功能。这两个库为开发者提供了便捷、高效...

    commons-fileupload-1.2.2-bin.zip

    7. **与Struts、Spring等框架的整合**:Commons FileUpload库可以轻松与主流的Java Web框架集成,如Struts、Spring MVC等,使得文件上传功能的实现更加便捷。 总的来说,Apache Commons FileUpload库是Java开发人员...

    commons-fileupload-1.3.3.jar commons-io-2.5.jar

    `commons-fileupload-1.3.3.jar` 和 `commons-io-2.5.jar` 是Apache Commons项目中的两个重要库,它们提供了强大的文件上传功能,使得开发者可以轻松地处理用户通过表单提交的文件。 Apache Commons FileUpload是...

    commons-fileupload使用例子

    本篇文章将详细介绍如何使用Apache Commons FileUpload来实现文件上传操作。 首先,我们需要了解HTTP协议在处理文件上传时的机制。通常,文件上传是通过`multipart/form-data`编码类型实现的,这种编码方式允许在...

    使用commons-fileupload实现的文件上传和下载

    通过以上步骤,你可以成功地使用Apache Commons FileUpload实现文件上传和下载功能,并避免中文乱码问题。在实际开发中,还可以结合Spring MVC或Struts等框架,进一步简化代码和提高代码的可维护性。

    commons-fileupload-1.2.1.zip

    使用Commons FileUpload时,首先需要配置Servlet容器以处理multipart请求。然后,创建一个`DiskFileItemFactory`实例来设置临时存储参数。接下来,使用`ServletFileUpload`构造器创建上传处理器,并调用其`parse...

    commons-fileupload-1.2.2.jar

    `commons-fileupload-1.2.2.jar`是Apache Commons ...然而,随着技术的发展,更现代的框架如Spring MVC已经内置了文件上传支持,但了解和掌握FileUpload的基本原理和使用仍然是Java Web开发者的必备技能之一。

    commons-fileupload相关架包

    在实际使用中,开发者通常会结合Servlet或者Spring MVC等Web框架来调用Commons FileUpload。在Servlet中,你需要创建一个`ServletFileUpload`实例并配置相关参数,然后调用`parseRequest`方法来解析请求。对于每个...

    commons-fileupload上传组件

    7. **与其他组件集成**:FileUpload常与Spring MVC、Struts等框架集成,处理文件上传请求。通过了解其工作原理,开发者可以更好地调试和优化与这些框架的交互。 总的来说,Apache Commons FileUpload是处理HTTP文件...

    commons-fileupload实现文件上传

    本篇将详细讲解如何使用Commons FileUpload来实现文件上传的功能。 首先,理解HTTP协议中的多部分数据是至关重要的。在HTML表单提交文件时,通常会使用`enctype="multipart/form-data"`属性,此时,数据会被分割成...

    commons-fileupload-1.4-src.zip

    9. **与Spring框架的整合**:在Spring MVC框架中,FileUpload可以与ModelAndView和MultipartFile接口一起使用,简化文件上传的处理逻辑。 10. **源码分析**:通过查看"commons-fileupload-1.4-src"中的源代码,...

    commons-fileupload-1.2.1帮助文档

    使用`commons-fileupload-1.2.1`前,需要在项目中引入对应的JAR包。对于Maven项目,可以通过添加依赖到`pom.xml`来实现: ```xml &lt;groupId&gt;commons-fileupload &lt;artifactId&gt;commons-fileupload &lt;version&gt;...

    commons-fileupload-1.3.3 commons-io-2.6

    在SSM中,文件上传通常涉及前端页面(由Struts处理)将文件传递给后端服务器(Spring控制),而 Commons FileUpload 和 Commons IO 就是处理这一过程的关键组件。 关于压缩包子文件的文件名称列表 "ssm_...

    commons-fileupload-1.2.2.jar和commons-io-2.4.jar包

    在实际应用中,开发者通常会结合Servlet或Spring MVC等框架,利用FileUpload和IO库提供的API来构建文件上传功能。例如,使用`DiskFileItemFactory`配置临时存储路径,创建`ServletFileUpload`实例来解析请求,再通过...

    commons-fileupload-1.2.1-bin.zip

    6. **与其他框架的集成**:Apache Commons FileUpload可方便地与Struts、Spring MVC等Web框架结合,提供优雅的文件上传解决方案。 总之,Apache Commons FileUpload 1.2.1是一个强大的文件上传组件,它简化了在Java...

Global site tag (gtag.js) - Google Analytics