SpringBoot请求参数传递与接收示例详解

2025-08-21 22:50

本文主要是介绍SpringBoot请求参数传递与接收示例详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《SpringBoot请求参数传递与接收示例详解》本文给大家介绍SpringBoot请求参数传递与接收示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...

I. 基础参数传递

i.查询参数(Query Parameters)

请求示例:GET /user?name=John&age=25

@GetMapping("/user")
public String getUser(
    @RequestParam String name, 
    @RequestParam(defaultValue = "20") int age) {
    return "Name: " + name + ", Age: " + age;
}

ii.路径参数(Path Variables)

请求示例:GET /product/123

@GetMapping("/product/{id}")
public String getProduct(@PathVariable Long id) {
    return "Product ID: " + id;
}

iii.混合

请求示例:GET /order/456?status=shipped

@GetMapping("/order/{orderId}")
public String getOrder(
    @PathVariable String orderId,
    @RequestParam String status) {
    return "Order " + orderId + " is " + status;
}

II. 对象绑定

i.自动绑定到实体类

请求示例:GET /search?keyword=spring&page=2&size=10

public class SearchParams {
    private String keyword;
    private int page = 1;
   www.chinasem.cn private int size = 20;
    // getters/setters方法
}
​
@GetMapping("/search")
public String search(SearchParams params) {
    return "Searching: " + params.getKeyword() 
           + " Page: " + params.getPage();
}

ii.嵌套对象绑定

请求示例:GET /user?name=Alice&address.city=Beijing&address.zip=100001

public class UserQuery {
    private String name;
    private Address address;
    // getters/setters
}
​
public class Address {
    private String city;
    private String zip;
}
​
@GetMapping("/user")
public String findUser(UserQuery query) {
    return query.getName() + " in " + query.getAddress().getCity();
}

III. JSON 请求体(POST/PUT/PATCH)

请求示例:POST /users Body: {"name":"Mike","email":"mike@example.com"}

// User实体
public class User {
    private String id;
    private String name;
    private String email;
    // getters/setters
}
​
@PostMapping("/users")
public User createUser(@RequestBody User user) {
    user.setId(UUID.randomUUID().toString());
    return user; // 自动转为JSON
}

IV、数组/集合参数

i.查询参数数组

请求示例:GET /products?ids=101,102,103

@GetMapping("/products")
public String getProducts(@RequestParam List<Long> ids) {
    return "IDs: " + ids.toString();
}

ii.JSON 数组

请求示例:POST /BATch Body: [{"name":"Item1"},{"name":"Item2"}]

@PostMapping("/batch")
public String batchCreate(@RequestBody List<Item> items) {
    return "Created " + items.size() + " items";
}

V、特殊参数处理

i.日期格式化

请求示例:GET /events?date=2023-05-15

@GetMapping("/events")
public String getEvents(@DateTimeFormat(pattern = "yyyy-MM-dd") Date date) {
    return "Events on: " + date.toString();
}

ii.可选参数

@GetMappwww.chinasem.cning("/optional")
public String optionalParam(@RequestParam(required = false) String filter) {
    return filter != null ? "Filter: " + filter : "No filter";
}

iii.请求头参数

@GetMapping("/auth")
public String auth(@RequestHeader("Authorization") String token) {
    return "Token: " + token.substring(0, 5) + "...";
}

VI、文件上传

表单请求:multipart/form-data

@PostMapping("/upload")
public String uploadFile(@RequestParam("file") MultipartFile file) {
    return "File received: " + file.getOriginalFilename() 
           + " Size: " + file.getSize();
}

VII、验证参数(需spring-boot-starter-validation)

POST /register

public class Registration {
    @NotBlank
    private China编程String username;
    @Email
    private String email;
    @Min(RnpOZSl18)
    private int age;
}
@PostMapping("/register")
public ResponseEntity<?> register(@Valid @RequestBody Registration form) {
    // 自动验证参数
    return ResponseEntity.ok("Valid");
}
// 全局异常处理
@ControllerAdvice
public class ValidationHandler {
    @ResponseStatus(HttpStatus.BAD_REQUEST)
    @ExceptionHandler(MethodArgumentNotValidException.class)
    public Map<String, String> handleValidation(MethodArgumentNotValidExcepRnpOZSltion ex) {
        Map<String, String> errors = new HashMap<>();
        ex.getBindingResult().getFieldErrors().forEach(error -> 
            errors.put(error.getField(), error.getDefaultMessage()));
        return errors;
    }
}

VIII、注解总结

注解用途示例场景
@RequestParam获取查询参数?name=value
@PathVariable获取路径参数/users/{id}
@RequestBody获取JSON/XML请求体POST/PUT请求
@ModelAttribute绑定表单数据html表单提交
@RequestHeader获取请求头值Authorization
@DateTimeFormat日期参数格式化?date=2023-01-01
@RequestPart文件上传multipart/form-data
@Valid触发参数验证配合JSR-303验证注解

到此这篇关于SpringBoot请求参数传递与接收示例整理的文章就介绍到这了,更多相关SpringBoot请求参数内容请搜索编程China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持China编程(www.chinasem.cn)!

这篇关于SpringBoot请求参数传递与接收示例详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155853

相关文章

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Spring 依赖注入与循环依赖总结

《Spring依赖注入与循环依赖总结》这篇文章给大家介绍Spring依赖注入与循环依赖总结篇,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. Spring 三级缓存解决循环依赖1. 创建UserService原始对象2. 将原始对象包装成工

Java中如何正确的停掉线程

《Java中如何正确的停掉线程》Java通过interrupt()通知线程停止而非强制,确保线程自主处理中断,避免数据损坏,线程池的shutdown()等待任务完成,shutdownNow()强制中断... 目录为什么不强制停止为什么 Java 不提供强制停止线程的能力呢?如何用interrupt停止线程s

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Java MCP 的鉴权深度解析

《JavaMCP的鉴权深度解析》文章介绍JavaMCP鉴权的实现方式,指出客户端可通过queryString、header或env传递鉴权信息,服务器端支持工具单独鉴权、过滤器集中鉴权及启动时鉴权... 目录一、MCP Client 侧(负责传递,比较简单)(1)常见的 mcpServers json 配置

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队