SpringMvc实现图片上传

Bertha 。 2022-05-12 13:50 455阅读 0赞

首先是设置一下tomcat的虚拟路径,有两种方法(以在C:/upfile/为例)

  • 第一种是在tomcat的bin目录下的server.xml添加一句

< Context docBase=“C:/upfile/” path=”/upload” reloadable=“false”/>
/upload就是虚拟路径,在下面的文件可以在浏览器localhost:8080 /upload/。。。访问到

  • 第二种是在idea下的简单设置,如下
  • 在这里插入图片描述

在这里插入图片描述

访问localhost:8080/upfile/404.jpg
在这里插入图片描述

编写一个简单的文件上传页面uploadPictureJsp.jsp

  1. <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
  2. <%--
  3. Created by IntelliJ IDEA.
  4. User: Administrator
  5. Date: 2018/10/23
  6. Time: 13:48
  7. To change this template use File | Settings | File Templates.
  8. --%>
  9. <%@ page contentType="text/html;charset=UTF-8" language="java" %>
  10. <html>
  11. <head>
  12. <title>上传图片</title>
  13. </head>
  14. <body>
  15. <form action="/upfile.do" method="post" enctype="multipart/form-data">
  16. <c:if test="${picture!=null}">
  17. <img src="/upfile/${picture}" width="100px" height="100px">
  18. </c:if>
  19. <input type="file" name="picture">
  20. <input type="submit">
  21. </form>
  22. </body>
  23. </html>

关于enctype问题可以看这里

然后就是控制器类uploadFile,放在/uploadPicture下

需要导入两个包
在这里插入图片描述

  1. package uploadPicture;
  2. import org.springframework.stereotype.Controller;
  3. import org.springframework.ui.Model;
  4. import org.springframework.web.bind.annotation.RequestMapping;
  5. import org.springframework.web.multipart.MultipartFile;
  6. import javax.servlet.http.HttpServletRequest;
  7. import java.io.File;
  8. import java.io.IOException;
  9. import java.util.UUID;
  10. /**
  11. * Created by Administrator on 2018/10/23.
  12. */
  13. @Controller
  14. public class uploadFile {
  15. @RequestMapping("/upfile.do")
  16. public String upfile(Model model, HttpServletRequest request, MultipartFile picture)
  17. throws IOException {
  18. // String picrureName=request.getParameter("picture");
  19. request.setAttribute("picture",picture.getOriginalFilename());
  20. String picName= UUID.randomUUID().toString();
  21. String oriName=picture.getOriginalFilename();
  22. String extName=oriName.substring(oriName.lastIndexOf("."));
  23. picture.transferTo(new File("C:/upfile1/"+picName+extName));
  24. System.out.println(request.getParameter("picture"));
  25. return "forward:/uploadPictureJsp.jsp";
  26. }
  27. }

需要在springmvc的配置文件demo1.xml配置一下

  1. <!-- 文件上传,id必须设置为multipartResolver -->
  2. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  3. <!-- 设置文件上传大小 5M -->
  4. <property name="maxUploadSize" value="5000000" />
  5. </bean>

ok,简单的上传文件的demo完成了

发表评论

表情:
评论列表 (有 0 条评论,455人围观)

还没有评论,来说两句吧...

相关阅读

    相关 springmvc实现图片

    springmvc实现多图片上传: 主要是项目要做的是一个发表分享的功能,就有点像微信发朋友圈那样,一个内容文字和图片显示。 思路:用form表单提交,在f