一、需求:

  利用SpringMVC实现上传文件的功能

  二、思路:

  1.我们可以在SpringMVC中,通过配置一个MultipartResolver来上传文件。

  2.通过MultipartFile file来接收文件,通过MultipartFile[] files接收多个文件上传。

  三、参考

  1.SpringMVC学习:https://how2j.cn/k/springmvc/springmvc-springmvc/615.html?p=36286

  四、步骤

  1.添加pom文件

  commons-fileupload

  commons-fileupload

  1.3.1

  commons-io

  commons-io

  2.3

  2.JSP页面

  上传页面,需要在src/main/resources/views下面新建一个upload.jsp文件

  3.跳转页面

  添加能跳转到upload页面的ViewController。需要在MyMvcConfig.java下面添加。

  // 添加转向upload页面的ViewController

  public void addViewControllers(ViewControllerRegistry registry) {

  registry.addViewController("/index").setViewName("/index");

  registry.addViewController("/toUpdate").setViewName("/upload");

  }

  4.MultipartResolver配置

  同样,在MyMvcConfig.java下面添加。

  // MultipartResolver配置

  @Bean

  public MultipartResolver multipartResolver() {

  CommonsMultipartResolver multipartResolver = new CommonsMultipartResolver();

  multipartResolver.setMaxUploadSize(1000000);

  return multipartResolver;

  }

  5.控制器(控制层)

  package com.eleven.controller;

  import java.io.File;

  import java.io.IOException;

  import org.apache.commons.io.FileUtils;

  import org.springframework.stereotype.Controller;

  import org.springframework.web.bind.annotation.RequestMapping;

  import org.springframework.web.bind.annotation.RequestMethod;

  import org.springframework.web.bind.annotation.ResponseBody;

  import org.springframework.web.multipart.MultipartFile;

  @Controller // 在@controller注解中,返回的是字符串,或者是字符串匹配的模板名称,即直接渲染视图,与html页面配合使用的

  public class UploadController {

  // @RequestMapping:是用来处理地址映射的注解

  // value:指定请求的实际地址

  // method:指定请求的方法类型,有get、post、put、delete

  @RequestMapping(value = "/upload", method = RequestMethod.POST)

  // 使用MultipartFile file接收上传的文件

  // @ResponseBody:将java对象转为json格式的数据。

  public @ResponseBody String upload(MultipartFile file) {

  try {

  // 使用FileUtils.writeByteArrayToFile快速写文件到磁盘

  FileUtils.writeByteArrayToFile(new File("D:upload/" + file.getOriginalFilename()), file.getBytes());

  return "ok";

  } catch (IOException e) {

  // TODO Auto-generated catch block

  e.printStackTrace();

  return "wrong";

  }

  }

  }

  6.运行

  访问路径: http://localhost:8080/springmvc/upload 即可。

SpringMVC 之 上传文件的更多相关文章

  1. 【SpringMVC】使用SpringMVC进行上传文件!

    写在前面: 之前在上传文件的时候,使用的是commons-file-upload这个插件,非常方便,能控制每个文件的大小,总共大小,缓存,以及支持多个文件的同时上传,但是写一次上传文件的后台代码量太大 ...

  2. 基于SpringMVC的上传文件实现

    基于SpringMVC的上传文件实现 1.项目源码 源码地址:upload 2.关键代码 @RequestMapping("/upload2") public void datal ...

  3. SpringMVC 学习-上传文件分解器 CommonsMultipartResolver 类

    Spring 组件 CommonsMultipartResolver 类的主要作用是配置文件上传的一些属性,也可以控制上传文件的大小. 在 springmvc-servlet.xml 配置文件中: & ...

  4. springmvc+ajaxFileUpload上传文件(前后台彻底分离的情况下)

    首先是导入jar包: web.xml: <servlet> <servlet-name>mvc-dispatcher</servlet-name> <serv ...

  5. SpringMVC在上传文件的时候提示The current request is not a multipart request错误

    @RequestMapping("/insertOrder") @ResponseBody public  Object insertOrder(String userId,Htt ...

  6. SpringMvc(注解)上传文件的简单例子

    spring mvc(注解)上传文件的简单例子,这有几个需要注意的地方1.form的enctype=”multipart/form-data” 这个是上传文件必须的2.applicationConte ...

  7. springmvc.xml 上传文件的配置

    <bean id="multipartResolver" class="org.springframework.web.multipart.commons.Comm ...

  8. Springmvc异步上传文件

    <script src="js/jquery.js" type="text/javascript"></script><scrip ...

  9. SpringMVC,SpringBoot上传文件简洁代码

    @RequestMapping("/updateAvatar.html") public String updateHeadUrl(MultipartFile avatar, Mo ...

随机推荐

  1. MVC 身份证图像识别(调用dll)

    源码下载 -> 提取码 QQ505645074 Index.cshtml <!DOCTYPE html> <html> <head> <meta cha ...

  2. 去掉没用的参数的warning

    #define UNUSED(x) ((void)(x)) void fun(int noused_arg, int b){ UNUSED(noused_arg); printf("%d\n ...

  3. Linux—使用man命令:man:command not found

    # 用echo $PATH查看该环境变量.这种问题一般是环境变量PATH不对的问题. [root@localhost ~]# echo $PATH # 用whereis命令查看,该指令的位置. [ro ...

  4. Linxu:磁盘分区

    了解磁盘分区 磁盘的物理组成: 圆形的磁盘盘(主要记录数据的部分): 机械手臂,与在机械手臂上的磁盘读取头(可擦写磁盘盘上的数据): 主轴马达,可以转动磁盘盘,让机械手臂的读取头在磁盘盘上读写数据. ...

  5. Tensorflow之单变量线性回归问题的解决方法

    跟着网易云课堂上面的免费公开课深度学习应用开发Tensorflow实践学习,学到线性回归这里感觉有很多需要总结,梳理记录下阶段性学习内容. 题目:通过生成人工数据集合,基于TensorFlow实现y= ...

  6. IntelliJ IDEA 版本控制 GIT(四)

    1. 从GitLab或GitGitHub中检出项目 VCS - Checkout from Version Control - Git 2. 更新项目 第一种:更新当前窗口下的整个项目 第二种:更新相 ...

  7. 期望DP的一般思路

    期望DP的一般思路 转载自_new2zy_ 期望\(dp\),也加概率\(dp\) 一般来说,期望\(dp\)找到正确的状态后,转移是比较容易想到的. 但一般情况下,状态一定是"可数&quo ...

  8. 前端Vue项目——购物车页面

    一.加入购物车的两种策略 1.加入购物车接口 在 src/restful/api.js 中写入添加购物车接口: // 加入购物车的接口 export const shopCart = (params) ...

  9. Paper | Non-Local ConvLSTM for Video Compression Artifact Reduction

    目录 1. 方法 1.1 框图 1.2 NL流程 1.3 加速版NL 2. 实验 3. 总结 [这是MFQE 2.0的第一篇引用,也是博主学术生涯的第一篇引用.最重要的是,这篇文章确实抓住了MFQE方 ...

  10. vs安装包离线下载

    1.首先打开visual studio 的官网下载最新的安装程序. https://www.visualstudio.com/zh-hans/?rr=https%3A%2F%2Fwww.baidu.c ...