基于Spring3 MVC实现基于HTML form表单文件上传

简介: 基于Spring3 MVC实现基于HTML form表单文件上传

基于Spring3 MVC实现基于form表单文件上传


一:杂项准备


环境搭建参考这里-http://blog.csdn.net/jia20003/article/details/8471169


二:前台页面


根据RFC1867,只要在提交form表单中声明提交方法为POST,enctype属


性声明为multipart/form-data, action声明到要提交的url即可。具体如下:

1357470742_8718.png



三:spring配置


使用spring3的MultipartHttpReqest来接受来自浏览器的发送的文件内容。


需要配Multipart解析器在express-servlet.xml中。内容如下:

1357470770_2552.png



同时还需要在maven的pom.xml文件添加apachefileupload与common-io两个包。


1357470796_6012.png


四:Controller中方法实现

@RequestMapping(value = "/uploadFile", method = RequestMethod.POST)
public ModelAndView getUploadFile(HttpServletRequest request, HttpServletResponse response) {
  System.out.println("fucking spring3 MVC upload file with Multipart form");
  String myappPath = request.getSession().getServletContext().getRealPath("/");
  try {
    if (request instanceof MultipartHttpServletRequest) {
      MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
      System.out.println("fucking spring3 MVC upload file with Multipart form");
      // String myappPath = multipartRequest.getServletContext().getRealPath("/"); 
      // does not work, oh my god!!
      MultipartFile file = multipartRequest.getFiles("userfile1").get(0);
      long size = file.getSize();
      byte[] data = new byte[(int) size];
      InputStream input = file.getInputStream();
      input.read(data);
      
      // create file, if no app context path, will throws access denied.
      // seems like you could not create any file at tomcat/bin directory!!!
      File outFile = new File(myappPath + File.separator + file.getOriginalFilename());
      if(!outFile.exists()) {
        outFile.createNewFile();
        System.out.println("full path = " + outFile.getAbsolutePath());
      } else {
        System.out.println("full path = " + outFile.getAbsolutePath());
      }
      FileOutputStream outStream = new FileOutputStream(outFile);
      
      outStream.write(data);
      outStream.close();
      input.close();
    }
  } catch (Exception e) {
    e.printStackTrace();
  }
 
  return new ModelAndView("welcome");
}

常见问题:


1. java.io.IOException: Access is denied避免这个错误是把文件创建在app


context path的下面所以要获取servlet context的本地路径。


2. Request类型不是MultipartHttpReqest类型,原因是没有配置spring的Multipart解析器


Chrome中运行截屏:

1357471347_1534.png



转载请注明

相关文章
|
13天前
|
移动开发 UED HTML5
HTML 表单和输入7
HTML 表单标签包括 `<form>`、`<input>`、`<textarea>`、`<label>`、`<fieldset>`、`<legend>`、`<select>`、`<optgroup>`、`<option>` 和 `<button>` 等,用于创建用户输入界面。HTML5 新增了 `<datalist>`、`<keygen>` 和 `<output>` 标签,增强了表单的功能和用户体验。
|
13天前
HTML 表单和输入6
提交按钮 `<input type="submit">` 用于将表单数据发送到服务器。表单的 `action` 属性指定接收数据的服务器文件,而 `method` 属性定义了提交方式(`get` 或 `post`)。`get` 方法将数据附加在 URL 后,适用于非敏感信息;`post` 方法将数据包含在请求体中,适用于敏感数据。示例展示了如何使用这两种方法提交表单。
|
8天前
|
前端开发 JavaScript 安全
HTML+CSS+JS密码灯登录表单
通过结合使用HTML、CSS和JavaScript,我们创建了一个带有密码强度指示器的登录表单。这不仅提高了用户体验,还帮助用户创建更安全的密码。希望本文的详细介绍和代码示例能帮助您在实际项目中实现类似功能,提升网站的安全性和用户友好性。
19 3
|
14天前
HTML 表单和输入5
复选框(Checkboxes)由 `<input type="checkbox">` 定义,允许用户选择一个或多个选项。
|
14天前
HTML 表单和输入2
HTML 表单是用于收集用户输入的区域,包含各种表单元素如文本域、下拉列表、单选框和复选框等。使用 `<form>` 标签创建表单,其中包含多个 `<input>` 元素来定义不同的输入类型。
|
14天前
HTML 表单和输入3
HTML 表单中的 `<input>` 标签是最常用的表单元素,其类型由 `type` 属性定义。常见的输入类型包括文本域(`<input type="text">`),用于用户在表单中输入字母和数字。
|
14天前
|
数据安全/隐私保护
HTML 表单和输入4
密码字段使用 `<input type="password">` 定义,输入的字符会被隐藏为星号或圆点。单选按钮使用 `<input type="radio">` 定义,用户只能选择一个选项。
|
3月前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
47 0
|
6月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
191 0
|
6月前
|
开发框架 前端开发 JavaScript
JavaScript云LIS系统源码ASP.NET CORE 3.1 MVC + SQLserver + Redis医院实验室信息系统源码 医院云LIS系统源码
实验室信息系统(Laboratory Information System,缩写LIS)是一类用来处理实验室过程信息的软件,云LIS系统围绕临床,云LIS系统将与云HIS系统建立起高度的业务整合,以体现“以病人为中心”的设计理念,优化就诊流程,方便患者就医。
78 0

热门文章

最新文章