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原创文章,未经博主允许不得转载。

相关文章推荐

zyUpload结合SpringMVC实现批量图片的上传

zyUpload是一款优秀的图片批量上传插件,浏览器兼容性强,应用方便便捷,特别适用于批量图片(当然不仅仅支持图片)文件的上传。这里我结合自己开发的一个例子,讲解下zyUpload结合SpringMV...

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

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

【uploadify2.1使用一】【Spring MVC uploadify2.1】批量文件、图片上传

今天在做一个批量上传图片的需求,google下,觉得uploadify在jquery的上传控件还是挺不错,特写下怎么使用。 1、下载资源包,2.1.0整理,免费分享地址 http://downlo...

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

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

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

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

springmvc批量文件打包成zip下载功能

1.页面上遍历checkbox $("#checkAll").click(function(){     if(this.checked){             $(".t...

使用WebUploader客户端批量上传图片,后台使用springMVC接收实例

使用WebUploader客户端批量上传图片,后台使用springMVC接收实例我是搞java后台的,因为最近主管让用webUploader写客户端,但是在网上找了很多,能够复制就能用的并没有几个,但...

关于阿里云服务器Linux安装Tomcat后,外网不能访问解决方案

这里需要提及三个方面的问题第一个方面:Linux上启动防火墙的问题 当下比较流行的Linux镜像是CentOS,所以防火墙也随之变成了firewall,那么怎么操作这个防火墙呢?#停止firewal...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

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