spring mvc 批量上传+文件上传

原创 2015年07月11日 07:19:24

spring mvc 批量上传+文件上传

简单3步走。搞定!

上传文件成功后:



1 上传文件核心方法

  1. public static String saveWebImgFile(MultipartFile imgFile){  
  2.         String webFilePath = "";  
  3.         if(imgFile.getSize() > 0 && isImage(imgFile.getContentType())){  
  4.             FileOutputStream fos = null;  
  5.             try {  
  6.                 byte[] b = imgFile.getBytes();  
  7.                 /* 构造文件路径 */  
  8.                 String webRoot = PathUtil.classPath();  
  9.                 SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMdd");  
  10.                 SimpleDateFormat sdf2 = new SimpleDateFormat("HHmmssSSS");  
  11.                 String datePath = sdf.format(new Date());  
  12.                 String datePath2 = sdf2.format(new Date());  
  13.                 String dirPath = webRoot + "/../../upload/img/" + datePath;  
  14.                 File dir = new File(dirPath);  
  15.                 if(!dir.exists()){  
  16.                     dir.mkdirs();  
  17.                 }  
  18.                 String fileName = imgFile.getOriginalFilename();  
  19.                 String filePath = dirPath + "/" + datePath2 + getImgSuffix(fileName);  
  20.                 webFilePath = "/upload/img/" + datePath + "/" + datePath2 + getImgSuffix(fileName);  
  21.                 File file = new File(filePath);  
  22.                   
  23.                 dir.setWritable(true);  
  24.                 file.setWritable(true);  
  25.                   
  26.                 fos = new FileOutputStream(file);  
  27.                 fos.write(b);  
  28.                   
  29.             } catch (IOException e) {  
  30.                 throw new RuntimeException("文件上传失败!" ,e);  
  31.             }finally{  
  32.                 if(fos != null){  
  33.                     try {  
  34.                         fos.close();  
  35.                     } catch (IOException e) {  
  36.                         throw new RuntimeException("文件上传->输出流关闭失败!!!!" ,e);  
  37.                     }  
  38.                 }  
  39.             }  
  40.         }  
  41.           
  42.         return webFilePath;  
  43.     }  



2控制器代码

  1. @RequestMapping(value = "/imgupload")  
  2.      public String handleFormUpload(MultipartHttpServletRequest request) throws Exception{    
  3.          List<MultipartFile> files = request.getFiles("file");  
  4.          Map<String, String> imgs = new HashMap<String, String>();  
  5.          for (int i = 0; i < files.size(); i++) {  
  6.             String webpath = FileUtil.saveWebImgFile(files.get(i));  
  7.             imgs.put("img"+i, webpath);  
  8.         }  
  9.         request.setAttribute("imgs", imgs);  
  10.         return showImageList(request);  
  11.      }  



3 页面代码

  1. <body>  
  2.     商品图片设置:  
  3.     <form method="post"  enctype="multipart/form-data" action="product/imgupload" name="imagefrm">  
  4.     <table>  
  5.         <tr>  
  6.         <td>商品大图:默认宽度600px,高度600px</td>  
  7.         </tr>  
  8.         <tr>  
  9.         <td><input type="file" name="file"/><c:if test="${imgs.img0!=null&&imgs.img0!=''}"><img src="<%=basePath %>${imgs.img0 }" style="width:40;height:40px;"/></c:if></td>  
  10.         </tr>  
  11.         <tr>  
  12.         <td>添加多角度图片:默认宽度50px,高度50px</td>  
  13.         </tr>  
  14.         <tr>  
  15.         <td><input type="file" name="file"/><c:if test="${imgs.img1!=null&&imgs.img1!=''}"><img src="<%=basePath %>${imgs.img1 }" style="width:40;height:40px;"/></c:if></td>  
  16.         </tr>  
  17.         <tr>  
  18.         <td><input type="file" name="file"/><c:if test="${imgs.img2!=null&&imgs.img2!=''}"><img src="<%=basePath %>${imgs.img2 }" style="width:40;height:40px;"/></c:if></td>  
  19.         </tr>  
  20.         <tr>  
  21.         <td><input type="file" name="file"/><c:if test="${imgs.img3!=null&&imgs.img3!=''}"><img src="<%=basePath %>${imgs.img3 }" style="width:40;height:40px;"/></c:if></td>  
  22.         </tr>  
  23.         <tr>  
  24.         <td><input type="file" name="file"/><c:if test="${imgs.img4!=null&&imgs.img4!=''}"><img src="<%=basePath %>${imgs.img4 }" style="width:40;height:40px;"/></c:if></td>  
  25.         </tr>  
  26.         <tr>  
  27.         <td><input type="submit" value="上传所有图片"/></td>   
  28.         </tr>  
  29.     </table>  
  30. </form>  
  31.  </body>  
版权声明:本文为博主http://www.feixueteam.net原创文章,未经博主允许不得转载。

SpringMVC 文件上传配置,多文件上传,使用的MultipartFile

基本的SpringMVC的搭建在我的上一篇文章里已经写过了,这篇文章主要说明一下如何使用SpringMVC进行表单上的文件上传以及多个文件同时上传的步骤 SpringMVC 基础教程 框架分析:ht...

springMVC两种方式实现多文件上传及效率比较

springMVC实现多文件上传的方式有两种,一种是我们经常使用的以字节流的方式进行文件上传,另外一种是使用springMVC包装好的解析器进行上传。这两种方式对于实现多文件上传效率上却有着很大的差距...

SpringMVC+Ajax文件批量上传和下载

今天做了文件的上传下载,小小总结一下,基本的web项目建立及SpringMVC框架搭建此处不详细写出来了。 上传form:               上传Ajax: ...

springMVC一次选择多个图片上传

一次选择多个图片进行上传这是html5有的或者可以利用jq的控件也可以。我采用了html5来写的。由于spring采用name绑定,所以文件的name命名需要注意。下面有前端 controller 以...

Springmvc下一次选多个文件上传(一)Form提交

Springmvc下一次选多个文件上传(一)Form提交

spring mvc 批量上传+文件上传

spring mvc 批量上传+文件上传 简单3步走。搞定! 上传文件成功后: 1 上传文件核心方法 [java] view plaincopyprint?...

Spring MVC多个文件上传

在Spring的控制器中使用MultipartFile file来接收文件,通过MultipartFile[] files接收多个文件上传。首先添加文件上传的依赖: commons-fileu...

springmvc上传图片并显示图片--支持多图片上传

springmvc上传图片并显示图片(也能上传文件),多图片上传并显示图片,采用commons-fileupload,commons-io...

Delphi7高级应用开发随书源码

  • 2003年04月30日 00:00
  • 676KB
  • 下载

Springmvc+uploadify实现文件上传

Springmvc+uploadify实现文件上传      网上看了很多关于文件上传的帖子,众口不一,感觉有点乱,最近正好公司的项目里用到JQuery的uploadify控件做文件上传,...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:spring mvc 批量上传+文件上传
举报原因:
原因补充:

(最多只允许输入30个字)