Spring MVC 核心注解与文件上传教程

一、@RequestBody 注解详解
1. 基本使用

作用 :从 HTTP 请求体中获取数据,适用于 POST/PUT 请求。
限制:GET 请求无请求体,不可使用该注解。

示例代码
java 复制代码
@Controller
@RequestMapping("/demo01")
public class Demo01Controller {

    @PostMapping("/test1")
    public void test1(@RequestBody String requestBody, HttpServletResponse response) 
        throws IOException {
        System.out.println("请求体内容:" + requestBody);
        response.getWriter().write(requestBody);
    }
}
前端测试方式
  1. 表单提交 (默认格式:application/x-www-form-urlencoded
html 复制代码
<form action="/demo01/test1" method="post">
  <input type="text" name="id">
  <input type="text" name="name">
  <input type="submit">
</form>

输出示例id=2&name=zhangsan

  1. AJAX JSON 提交
javascript 复制代码
$("#btn").click(function() {
  const data = { id: 1, name: "吉林省" };
  $.post({
    url: "/demo01/test1",
    contentType: "application/json",
    data: JSON.stringify(data),
    success: function(res) { console.log(res); }
  });
});

输出示例{"id":1,"name":"吉林省"}


2. JSON 数据绑定

要求

  • 请求头必须包含 Content-Type: application/json
  • 需要 jackson-databind 依赖支持 JSON 转换
实体类与控制器
java 复制代码
@Data // Lombok 注解,自动生成 getter/setter
public class Province {
    private Integer id;
    private String name;
}

@RestController
@RequestMapping("/demo01")
public class Demo01Controller {

    @PostMapping("/test2")
    public Province test2(@RequestBody Province province) {
        System.out.println("接收对象:" + province);
        return province; // 自动转为 JSON 返回
    }
}
前端测试
javascript 复制代码
$("#btn").click(function() {
  const province = { id: 2, name: "重庆" };
  $.post({
    url: "/demo01/test2",
    contentType: "application/json",
    data: JSON.stringify(province),
    success: function(res) { console.log(res); }
  });
});

输出结果Province(id=2, name=重庆)


二、文件上传实战
1. 环境配置
依赖引入
xml 复制代码
<!-- 文件上传核心依赖 -->
<dependency>
    <groupId>commons-fileupload</groupId>
    <artifactId>commons-fileupload</artifactId>
    <version>1.4</version>
</dependency>
Spring 配置文件
xml 复制代码
<!-- 配置 MultipartResolver -->
<bean id="multipartResolver" 
      class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
    <property name="maxUploadSize" value="10240000"/> <!-- 最大10MB -->
    <property name="defaultEncoding" value="UTF-8"/>
</bean>

2. 单文件上传
前端表单
html 复制代码
<form enctype="multipart/form-data" action="/demo01/upload" method="post">
  <input type="file" name="myfile">
  <input type="submit">
</form>
控制器实现
java 复制代码
@PostMapping("/upload")
public void uploadFile(
    @RequestPart("myfile") MultipartFile file, 
    HttpServletResponse response) throws IOException {

    // 获取文件信息
    String fileName = file.getOriginalFilename();
    long size = file.getSize();
    
    // 保存到磁盘
    file.transferTo(new File("D:/uploads/" + fileName));
    
    // 返回响应
    response.setContentType("text/html;charset=utf-8");
    response.getWriter()
        .write("文件名:" + fileName + "<br>大小:" + size + "字节");
}

3. 多文件上传
前端表单
html 复制代码
<form enctype="multipart/form-data" action="/demo01/uploads" method="post">
  <input type="file" name="myfiles" multiple>
  <input type="file" name="myfiles">
  <input type="submit">
</form>
控制器实现
java 复制代码
@PostMapping("/uploads")
public String uploadFiles(@RequestPart("myfiles") MultipartFile[] files) 
    throws IOException {
    
    for (MultipartFile file : files) {
        if (!file.isEmpty()) {
            file.transferTo(new File("D:/uploads/" + file.getOriginalFilename()));
        }
    }
    return "上传成功!共处理 " + files.length + " 个文件";
}

三、注意事项
  1. 文件上传限制
    • 表单必须设置 enctype="multipart/form-data"
    • 提交方式必须为 POST
  2. 常见错误
    • 415 错误:未正确设置 Content-Type: application/json
    • 文件大小超限:检查 maxUploadSize 配置
  3. 依赖问题
    • 确保 Lombok、Jackson、commons-fileupload 版本匹配

通过本教程,您已掌握 Spring MVC 中请求体数据绑定和文件上传的核心技术。建议结合代码示例进行实际操作练习。

相关推荐
好学且牛逼的马22 分钟前
MyBatis-Plus的深度解析
java
苏纪云24 分钟前
数据结构<C++>——数组
java·数据结构·c++·数组·动态数组
典则1 小时前
STM32FreeRtos入门(五)——同步互斥与通信
java·jvm·stm32
你不是我我1 小时前
【Java 开发日记】我们来讲一讲阻塞队列及其应用
java·开发语言
互联网中的一颗神经元1 小时前
小白python入门 - 9. Python 列表2 ——从基础操作到高级应用
java·开发语言·python
大厂码农老A1 小时前
我带的外包兄弟放弃大厂转正,薪资翻倍入职字节
java·后端·面试
摇滚侠1 小时前
Spring Boot3零基础教程,生命周期监听,自定义监听器,笔记59
java·开发语言·spring boot·笔记
凯子坚持 c1 小时前
Llama-2-7b在昇腾NPU上的六大核心场景性能基准报告
java·开发语言·llama
百锦再1 小时前
国产数据库替代MongoDB的技术实践:金仓数据库赋能浙江省人民医院信息化建设新展望
java·开发语言·数据库·mongodb·架构·eclipse·maven
武子康1 小时前
Java-160 MongoDB副本集部署实战 单机三实例/多机同法 10 分钟起集群 + 选举/读写/回滚全流程
java·数据库·sql·mongodb·性能优化·系统架构·nosql