前提:引入jar包。
- <dependency>
- <groupId>commons-fileupload</groupId>
- <artifactId>commons-fileupload</artifactId>
- <version>1.3</version>
- </dependency>
一、配置文件:
SpringMVC 用的是 的MultipartFile来进行文件上传 所以我们首先要配置MultipartResolver:用于处理表单中的file
- <!-- SpringMVC上传文件时,需要配置MultipartResolver处理器 -->
- <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
- <property name="defaultEncoding" value="UTF-8" />
- <!-- 指定所上传文件的总大小不能超过200KB。注意maxUploadSize属性的限制不是针对单个文件,而是所有文件的容量之和 -->
- <!-- <property name="maxUploadSize" value="200000"/> -->
- <!-- 指定上传文件的临时路径 -->
- <!-- <property name="uploadTempDir" value="uploadTempDirectory" /> -->
- </bean>
属性详解:defaultEncoding="UTF-8" 是请求的编码格式,默认为iso-8859-1
maxUploadSize="200000" 是上传文件的大小,单位为字节
uploadTempDir="uploadTempDirectory" 为上传文件的临时路径
二、创建一个简单的上传表单:
- <form action="uploadId" method="post" enctype="multipart/form-data">
- <input type="file" name="idPic" />
- <button >Submit</button>
- </form>
注意:要在form标签中加上enctype="multipart/form-data"表示该表单是要处理文件的,这是最基本的东西,很多人会忘记然而当上传出错后则去找程序的错误,却忘了这一点三、编写上传控制类
1、创建一个控制类: FileUploadController,一个返回提交文件的页面
2、编写提交表单的action:
3、使用SpringMVC注解RequestParam来指定表单中的idPic参数;
4、指定一个用于保存文件的web项目路径
5、通过MultipartFile的transferTo(File dest)这个方法来转存文件到指定的路径。MultipartFile转存后,无法再操作,会报错
- <span style="white-space:pre"> </span>//通过Spring的autowired注解获取spring默认配置的request
- @Autowired
- private HttpServletRequest request;
-
- <span style="white-space:pre"> </span>/**
- * 跳转到上传文件的页面
- * @return
- */
- @RequestMapping(value = "/uploadPage")
- public String uploadPage() {
- return "upload";
- }
-
- /**
- * 上传文件 用@RequestParam注解来指定表单上的file为MultipartFile
- * @param multipartfile
- * @return
- * @throws IOException
- */
- @RequestMapping(value = "/uploadId")
- @ResponseBody
- public ResponseEntity<byte[]> idIdentification(@RequestParam("idPic") MultipartFile multipartfile) throws IOException {
- System.out.println("getOriginalFilename:"+multipartfile.getOriginalFilename());
- System.out.println("getName:"+multipartfile.getName());
- // 设置格式,图片
- HttpHeaders headers = new HttpHeaders();
- headers.setContentType(MediaType.IMAGE_JPEG);
-
- //保存文件到临时目录
- String savePath = request.getSession().getServletContext().getRealPath("/")
- + "/uploadTempDirectory/" + multipartfile.getOriginalFilename();
- File saveFile = new File(savePath);
- multipartfile.transferTo(saveFile);
- //页面显示用户上传的图片
- return new ResponseEntity<byte[]>(FileUtils.readFileToByteArray(saveFile), headers, HttpStatus.OK);
- }
到此基本的文件上传就结束了。
多文件上传:
多文件上传其实很简单,和上传其他相同的参数如checkbox一样,表单中使用相同的名称,然后action中将MultipartFile参数类定义为数组就可以。
接下来实现:
1、创建一个上传多文件的表单:
- <form action="multiUploadId" method="post" enctype="multipart/form-data">
- <input type="file" name="idPic" />
- <input type="file" name="idPic" />
- <input type="file" name="idPic" />
- <button >Submit</button>
- </form>
2、编写处理表单的action:
- <span style="white-space:pre"> </span>/**
- * 多文件上传
- * @param multipartfiles
- * @return
- * @throws IllegalStateException
- * @throws IOException
- */
- @RequestMapping(value = "/multiUploadId")
- public String multiUpload(@RequestParam("idPic") MultipartFile[] multipartfiles)
- throws IllegalStateException, IOException {
- //保存文件的目录
- String savePath = request.getSession().getServletContext().getRealPath("/") + "/uploadTempDirectory/";
- if(null != multipartfiles && multipartfiles.length > 0){
- //遍历并保存文件
- for(MultipartFile file : multipartfiles){
- file.transferTo(new File(savePath + file.getOriginalFilename()));
- }
- }
- return "redirect:uploadPage";
- }
运行实例,大功告成!