springMVC文件上传

简介: springMVC文件上传


Spring MVC 框架的文件上传基于 commons-fileupload 组件,并在该组件上做了进一步的封装,简化了文件上传的代码实现,取消了不同上传组件上的编程差异。

MultipartResolver接口

在 Spring MVC 中实现文件上传十分容易,它为文件上传提供了直接支持,即 MultpartiResolver 接口。MultipartResolver 用于处理上传请求,将上传请求包装成可以直接获取文件的数据,从而方便操作。

MultpartiResolver 接口有以下两个实现类:

StandardServletMultipartResolver:使用了 Servlet 3.0 标准的上传方式。
CommonsMultipartResolver:使用了 Apache 的 commons-fileupload 来完成具体的上传操作。
MultpartiResolver 接口具有以下方法。

名称

作用

byte[] getBytes()

以字节数组的形式返回文件的内容

String getContentType()

返回文件的内容类型

InputStream getInputStream()

返回一个InputStream,从中读取文件的内容

String getName()

返回请求参数的名称

String getOriginalFillename()

返回客户端提交的原始文件名称

long getSize()

返回文件的大小,单位为字节

boolean isEmpty()

判断被上传文件是否为空

void transferTo(File destination)

将上传文件保存到目标目录下

单文件上传

1.maven引入


commons-fileupload
commons-fileupload
1.4


commons-io
commons-io
2.11.0

  1. 配置 MultipartResolver

使用 CommonsMultipartReslover 配置 MultipartResolver 解析器,在 springmvc-servlet.xml 中添加代码如下。

<bean id="multipartResolver"

class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="maxUploadSize" value="5000000" />
<property name="defaultEncoding" value="UTF-8" />
AI 代码解读


defaultEncoding:请求的编码格式,默认为 ISO-8859-1,此处设置为 UTF-8(注:defaultEncoding 必须和 JSP 中的 pageEncoding 一致,以便正确读取表单的内容)。
maxUploadSize:上传文件大小上限,单位为字节。
3.编写文件上传表单页面

负责文件上传表单的编码类型必须是“multipart/form-data”类型。

文件:

备注: file 文件的name参数值与控制器类中的参数值保持一致。

  1. 编写控制器

@RestController
public class UploadController {

@PostMapping("/upload")
public String upload(MultipartFile multipartFile, HttpServletRequest request){

    //获取服务器根路径
    String root=request.getSession().getServletContext().getRealPath("/");
    //创建服务器附件的路径
    File dir=new File(root+"/attachment");
    //先判断目录 是否存在
    if(!dir.exists()){
        //创建目录
        dir.mkdir();
    }

    //获取原文件的后缀
    String name=multipartFile.getOriginalFilename();
    String ext=name.substring(name.lastIndexOf("."));
    String newFileName=System.currentTimeMillis()+ext;
    //要上传到服务上的新的文件
    File newFile=new File(dir,newFileName);

    try {
        multipartFile.transferTo(newFile);
        return "attachment/"+newFileName;
    } catch (IOException e) {
        e.printStackTrace();
        return null;
    }
}
AI 代码解读

}
多文件上传:

文件:


控制类

实现只要将参数改成List multipartFiles即可。

@RestController // 注册到ioc容器
@PropertySource("classpath:file.properties")
public class UploadController {

final String ATTACHMENT_DIRS="/attachment/";
final int  SUCCESS=200;
final int FAIL=0;

String root; //服务器根路径

@Autowired
HttpServletRequest req;

@Value("${upload.maxSize}")
long maxSize;

@Value("${upload.type}")
String type;


@PostMapping("/upload")
public UploadBean upload(MultipartFile multipartFile){
    createDir();
    return writeFile(multipartFile);
}


@PostMapping("/batchUpload")
public List uploadMulitFile(List<MultipartFile> multipartFiles){
    createDir();
    List list=new ArrayList();
    //遍历文件 列表
    Iterator<MultipartFile> it=multipartFiles.iterator();
    while (it.hasNext()){
        MultipartFile file=it.next();
        list.add(writeFile(file));
    }
    return list;
}


void createDir(){
    //获取服务器根路径
    //创建服务器附件的路径
    File dir=new File(getRoot()+ATTACHMENT_DIRS);
    //先判断目录 是否存在
    if(!dir.exists()){
        //创建目录
        dir.mkdir();
    }
}

/**
 * 将文件 写入服务器
 * @param file
 * @return
 */
UploadBean writeFile(MultipartFile file){
    if(file.isEmpty())
        return fail("上传的文件为空");
    //获取文件类型
    String ct=file.getContentType();
    if(type.indexOf(ct)==-1){
        return fail("暂不支持该格式的文件上传");
    }

    if(file.getSize()>maxSize){
        return fail("文件超过最大上传限制");
    }

    //获取新文件 名
    String fileName=getNewFileName(file);
    //创建新的文件
    File newFile=new File(getRoot()+ATTACHMENT_DIRS+fileName);
    //将文件写入服务器
    try {
        file.transferTo(newFile);
        return success(ATTACHMENT_DIRS+fileName);
    } catch (IOException e) {
        e.printStackTrace();
        return fail("上传失败:"+e.toString());
    }
}

/**
 * 生成新的文件名
 * @param file
 * @return
 */
String getNewFileName(MultipartFile file){
    //获取原文件的后缀
    String name=file.getOriginalFilename();
    String ext=name.substring(name.lastIndexOf("."));
    String newFileName=System.currentTimeMillis()+ext;
    return newFileName;
}

public String getRoot() {
    if(null==root && null!=req){
        root=req.getSession().getServletContext().getRealPath("/");
    }
    return root;
}

UploadBean success(Object data){
    return new UploadBean(SUCCESS,"上传成功",data);
}

UploadBean fail(String msg){
    return new UploadBean(FAIL,msg,null);
}
AI 代码解读

}
file.properties文件内容:

upload.maxSize=10485760
upload.type=image/jpeg,image/png
UploadBean.java

public class UploadBean {

int code;
String msg;
Object data;

public int getCode() {
    return code;
}

public void setCode(int code) {
    this.code = code;
}

public String getMsg() {
    return msg;
}

public void setMsg(String msg) {
    this.msg = msg;
}

public Object getData() {
    return data;
}

public void setData(Object data) {
    this.data = data;
}

public UploadBean(int code, String msg, Object data) {
    this.code = code;
    this.msg = msg;
    this.data = data;
}

public UploadBean() {
}
AI 代码解读

}

目录
打赏
0
0
0
0
0
分享
相关文章
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
本文介绍了 `@RequestParam` 注解的使用方法及其与 `@PathVariable` 的区别。`@RequestParam` 用于从请求中获取参数值(如 GET 请求的 URL 参数或 POST 请求的表单数据),而 `@PathVariable` 用于从 URL 模板中提取参数。文章通过示例代码详细说明了 `@RequestParam` 的常用属性,如 `required` 和 `defaultValue`,并展示了如何用实体类封装大量表单参数以简化处理流程。最后,结合 Postman 测试工具验证了接口的功能。
155 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestParam
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestBody
`@RequestBody` 是 Spring 框架中的注解,用于将 HTTP 请求体中的 JSON 数据自动映射为 Java 对象。例如,前端通过 POST 请求发送包含 `username` 和 `password` 的 JSON 数据,后端可通过带有 `@RequestBody` 注解的方法参数接收并处理。此注解适用于传递复杂对象的场景,简化了数据解析过程。与表单提交不同,它主要用于接收 JSON 格式的实体数据。
190 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@PathVariable
`@PathVariable` 是 Spring Boot 中用于从 URL 中提取参数的注解,支持 RESTful 风格接口开发。例如,通过 `@GetMapping(&quot;/user/{id}&quot;)` 可以将 URL 中的 `{id}` 参数自动映射到方法参数中。若参数名不一致,可通过 `@PathVariable(&quot;自定义名&quot;)` 指定绑定关系。此外,还支持多参数占位符,如 `/user/{id}/{name}`,分别映射到方法中的多个参数。运行项目后,访问指定 URL 即可验证参数是否正确接收。
128 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RequestMapping
@RequestMapping 是 Spring MVC 中用于请求地址映射的注解,可作用于类或方法上。类级别定义控制器父路径,方法级别进一步指定处理逻辑。常用属性包括 value(请求地址)、method(请求类型,如 GET/POST 等,默认 GET)和 produces(返回内容类型)。例如:`@RequestMapping(value = &quot;/test&quot;, produces = &quot;application/json; charset=UTF-8&quot;)`。此外,针对不同请求方式还有简化注解,如 @GetMapping、@PostMapping 等。
155 0
微服务——SpringBoot使用归纳——Spring Boot中的MVC支持——@RestController
本文主要介绍 Spring Boot 中 MVC 开发常用的几个注解及其使用方式,包括 `@RestController`、`@RequestMapping`、`@PathVariable`、`@RequestParam` 和 `@RequestBody`。其中重点讲解了 `@RestController` 注解的构成与特点:它是 `@Controller` 和 `@ResponseBody` 的结合体,适用于返回 JSON 数据的场景。文章还指出,在需要模板渲染(如 Thymeleaf)而非前后端分离的情况下,应使用 `@Controller` 而非 `@RestController`
134 0
Spring、SpringMVC 与 MyBatis 核心知识点解析
我梳理的这些内容,涵盖了 Spring、SpringMVC 和 MyBatis 的核心知识点。 在 Spring 中,我了解到 IOC 是控制反转,把对象控制权交容器;DI 是依赖注入,有三种实现方式。Bean 有五种作用域,单例 bean 的线程安全问题及自动装配方式也清晰了。事务基于数据库和 AOP,有失效场景和七种传播行为。AOP 是面向切面编程,动态代理有 JDK 和 CGLIB 两种。 SpringMVC 的 11 步执行流程我烂熟于心,还有那些常用注解的用法。 MyBatis 里,#{} 和 ${} 的区别很关键,获取主键、处理字段与属性名不匹配的方法也掌握了。多表查询、动态
第05课:Spring Boot中的MVC支持
第05课:Spring Boot中的MVC支持
对Spring、SpringMVC、MyBatis框架的介绍与解释
Spring 框架提供了全面的基础设施支持,Spring MVC 专注于 Web 层的开发,而 MyBatis 则是一个高效的持久层框架。这三个框架结合使用,可以显著提升 Java 企业级应用的开发效率和质量。通过理解它们的核心特性和使用方法,开发者可以更好地构建和维护复杂的应用程序。
278 29
步步深入SpringMvc DispatcherServlet源码掌握springmvc全流程原理
通过对 `DispatcherServlet`源码的深入剖析,我们了解了SpringMVC请求处理的全流程。`DispatcherServlet`作为前端控制器,负责请求的接收和分发,处理器映射和适配负责将请求分派到具体的处理器方法,视图解析器负责生成和渲染视图。理解这些核心组件及其交互原理,有助于开发者更好地使用和扩展SpringMVC框架。
128 4
Spring MVC中的请求映射:@RequestMapping注解深度解析
在Spring MVC框架中,`@RequestMapping`注解是实现请求映射的关键,它将HTTP请求映射到相应的处理器方法上。本文将深入探讨`@RequestMapping`注解的工作原理、使用方法以及最佳实践,为开发者提供一份详尽的技术干货。
677 2

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问