前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Maven+SpringMVC+MyBatis 上传图片

Maven+SpringMVC+MyBatis 上传图片

作者头像
用户1737026
发布2018-05-17 17:14:29
1.1K0
发布2018-05-17 17:14:29
举报
文章被收录于专栏:五毛程序员

  上传文件我一直都觉得很难,好吧,所有涉及文件操作的我都觉得不容易。然后今天尝试了从网页上传图片保存到服务器。这个例子的前提是搭建好了服务器端框架:Maven+Spring MVC+MyBatis。当然必要的准备我也要提及。

  首先是jar包,上传文件必不可少的jar包:commons-fileupload和commons-io。这两个是apache的开源jar包。

  Maven配置:

代码语言:javascript
复制
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.3.1</version>
</dependency>
<dependency>
    <groupId>commons-io</groupId>
    <artifactId>commons-io</artifactId>
    <version>2.4</version>
</dependency>

  有了这两个jar包基本上就行了。

  还有一个准备工作是对SpringMVC上传文件的配置:

代码语言:javascript
复制
<!-- 对上传文件的配置 -->
<bean id="multipartResolver"
        class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="defaultEncoding">
        <value>UTF-8</value>
    </property>
    <property name="maxUploadSize">
        <value>32505856</value><!-- 上传文件大小限制为31M,31*1024*1024 -->
    </property>
    <property name="maxInMemorySize">
        <value>4096</value>
    </property>
</bean>

  接下来是上传文件的jsp页面,当然一般的html页面也是可以的。特别要注意的是,form表单里面有文件上传时,必须要指定enctype属性值为multipart/form-data,意思是以二进制流的形式传输文件。否则会上传不了,会报错的。

代码语言:javascript
复制
 1 <%@ page language="java" contentType="text/html; charset=UTF-8"
 2     pageEncoding="UTF-8"%>
 3 <!DOCTYPE html>
 4 <html lang="en">
 5 <head>
 6     <meta charset="UTF-8">
 7     <title>Document</title>
 8 </head>
 9 <body>
10     <form action="appuser/uploadHeadPhoto.do"
11     method="POST" enctype="multipart/form-data" >
12         <input type="file" name="headPhotoFile">
13         <input type="text" name="userId" value="1" readonly>
14         <button type="submit" value="提交">提交</button>
15     </form>
16 </body>
17 </html>

  后台Controller处理文件上传的接口,主要过程是获取文件二进制流,然后写入新创建的jpg,返回新创建的jpg的地址,将地址写入数据库。数据库里面最终存放的jpg图片路径是D:\Program Files\apache-tomcat-7.0.62\webapps\springmvcImage\14386803406181764242780.jpg。

代码语言:javascript
复制
 1 @RequestMapping("/uploadHeadPhoto")
 2     public String uploadHeadPhoto(@RequestParam MultipartFile headPhotoFile, HttpServletRequest request) throws IOException{
 3         String userId = request.getParameter("userId");
 4         
 5         if(headPhotoFile.isEmpty()){
 6             System.out.println("文件未上传");
 7         }else{
 8             String contentType = headPhotoFile.getContentType();
 9             System.out.println(contentType);//输出image/jpeg
10             if(contentType.startsWith("image")){
11                 //获取Web项目的全路径
12                 String realPath = request.getSession().getServletContext().getRealPath("/");
13                 System.out.println(realPath);//输出D:\Program Files\apache-tomcat-7.0.62\webapps\springmvc\
14                 realPath = realPath.replace("springmvc", "springmvcImage");
15                 realPath.concat("user");
16                 String newFileName = new Date().getTime()+""+new Random().nextInt()+".jpg";
17                 FileUtils.copyInputStreamToFile(headPhotoFile.getInputStream(), new File(realPath, newFileName));
18                 
19                 //将图片路径插入数据库
20                 Map<String, Object> requestMap = new HashMap<String, Object>();
21                 requestMap.put("userId", userId);
22                 requestMap.put("headPhoto", realPath+newFileName);
23                 int flag = userService.uploadHeadPhoto(requestMap);
24                 if(flag!=0&&flag!=-1){
25                     System.out.println("success");
26                     return "success";
27                 }
28             }
29         }
30         
31         return null;
32     }
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2015-08-04 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档