Spring Boot (通过Spring MVC) 提供了强大的机制来处理不同 Content-Type? 的HTTP请求体。这主要依赖于 HttpMessageConverter? 接口的各种实现,它们能够自动将请求体内容转换成Java方法参数。
Spring MVC会根据请求头中的 Content-Type? 和Controller方法参数的类型,选择一个合适的 HttpMessageConverter? 来执行数据转换。常见的转换器包括:
1 2 3 4 5 6 7 8 9 10 11 |
// POJO // public class User { // private String username; // private String email; // // getters and setters // } @PostMapping("/users") public User createUser(@RequestBody User user) { // user 对象已从JSON填充 return userService.save(user); } |
说明: 请求体中的JSON字符串会被自动映射到 User? 对象的字段。
1 2 3 4 5 |
@PostMapping("/login") public String login(@RequestParam String username, @RequestParam String password) { // username 和 password 从表单数据填充 // ... } |
1 2 3 4 5 6 7 8 9 10 11 |
// POJO // public class RegistrationForm { // private String username; // private String password; // // getters and setters // } @PostMapping("/register") public String register(RegistrationForm form) { // form 对象已从表单数据填充 // ... } |
1 2 3 |
spring.servlet.multipart.enabled=true spring.servlet.multipart.max-file-size=10MB spring.servlet.multipart.max-request-size=10MB |
示例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 |
@PostMapping("/upload/profile") public String uploadProfile(@RequestParam("userId") Long userId, @RequestParam("image") MultipartFile imageFile) throws IOException { // userId 是普通表单字段 // imageFile 是上传的文件 String fileName = imageFile.getOriginalFilename(); // ... 保存文件 ... return "File " + fileName + " uploaded for user " + userId; } // 使用 @RequestPart 处理复杂multipart (例如,一个部分是JSON) @PostMapping("/upload/advanced") public String advancedUpload(@RequestPart("metadata") UserMetadata metadata, // UserMetadata 是一个POJO @RequestPart("document") MultipartFile document) { // metadata 从一个JSON part解析 // document 是文件 part // ... return "Advanced upload successful."; } |
1 2 3 4 5 |
@PostMapping("/logs") public void submitLog(@RequestBody String logEntry) { // logEntry 包含请求体中的纯文本 System.out.println(logEntry); } |
1 2 3 4 5 6 7 8 9 10 11 |
// POJO (用JAXB注解) // @XmlRootElement(name = "item") // public class Item { // @XmlElement public String name; // @XmlElement public double price; // } @PostMapping(value = "/items", consumes = "application/xml", produces = "application/xml") public Item createItem(@RequestBody Item item) { // item 对象已从XML填充 return itemService.save(item); } |
1 2 3 4 5 6 |
@PostMapping(value = "/data", consumes = "application/octet-stream") public String processBinaryData(@RequestBody byte[] data) { // data 包含原始二进制数据 System.out.println("Received " + data.length + " bytes."); return "Binary data processed."; } |
或者直接使用 InputStream? (通常不带 @RequestBody?):
1 2 3 4 5 6 |
@PostMapping(value = "/data-stream", consumes = "application/octet-stream") public String processDataStream(InputStream inputStream) throws IOException { // 手动从 inputStream 读取数据 // ... return "Stream processed."; } |
如果请求的 Content-Type? 不被支持,或者请求体格式错误(如无效的JSON),Spring Boot 通常会返回:
开发者可以注册自定义的 HttpMessageConverter? 来支持非标准或特定的数据格式,通过配置 WebMvcConfigurer?。
1 2 3 4 5 6 7 8 9 10 11 12 13 |
// @Configuration // public class WebConfig implements WebMvcConfigurer { // @Override // public void configureMessageConverters(List<HttpMessageConverter<?>> converters) { // converters.add(new MyCustomMessageConverter()); // } // // @Override // public void extendMessageConverters(List<HttpMessageConverter<?>> converters) { // // 用来添加转换器,同时不影响默认注册的转换器 // // 或者调整已注册转换器的顺序 // } // } |
理解这些机制对于构建健壮和灵活的Spring Boot API至关重要。