Spring Boot 中的 @RequestParam:获取查询参数与表单数据

简介: `@RequestParam` 用于提取 HTTP 请求中的查询参数或表单数据,支持设置参数名、是否必填及默认值。适用于 `?key=value` 形式或 POST 表单,字段多时推荐封装为实体类自动绑定,与 `@PathVariable` 按路径取值不同,用途明确,是处理 Web 请求的常用方式。

@RequestParam 用于从 HTTP 请求的查询字符串(Query String)或表单数据(Form Data) 中提取参数,适用于如下 URL 格式:

GET /user?id=123&name=tom
POST /login (表单提交 username 和 password)

@PathVariable 的区别

注解 参数来源 URL 示例
@PathVariable 路径占位符 /user/123
@RequestParam 查询参数或表单字段 /user?id=123 或 POST 表单

基本用法

@GetMapping("/user")
public String getUser(@RequestParam Integer id) {
    System.out.println("ID: " + id);
    return "success";
}

访问 /user?id=100 → 正常获取 id = 100


常用属性

  • value:指定请求参数名(当与方法参数名不一致时使用)  
  • required:是否必传,默认 true;设为 false 可选  
  • defaultValue:参数未提供时的默认值
@GetMapping("/search")
public String search(
    @RequestParam(value = "keyword", required = false, defaultValue = "未知") String kw
) {
    System.out.println("搜索关键词:" + kw);
    return "success";
}

接收表单数据(POST)

对于少量字段,可直接用 @RequestParam

@PostMapping("/form1")
public String login(
    @RequestParam String username,
    @RequestParam String password
) {
    // 处理登录
}

字段较多时,推荐封装为实体类

public class User {
    private String username;
    private String password;
    // getter / setter
}
@PostMapping("/form2")
public String register(User user) { // 自动绑定同名参数
    System.out.println(user.getUsername());
    return "success";
}

✅ 注意:使用实体接收时,不要加 @RequestParam,Spring Boot 会自动将请求参数映射到对象属性。


小结

  • @RequestParam 用于获取 ?key=value 或表单参数;
  • 支持设置默认值、可选参数;
  • 字段少可用注解逐个接收,字段多应使用实体类自动绑定;
  • @PathVariable 用途不同,勿混淆。

这是处理传统 Web 表单和查询接口的常用方式。


相关文章
|
5月前
|
Java API Spring
Spring Boot 中的 @PathVariable:获取 RESTful 路径参数
在Spring Boot中,`@PathVariable`用于提取RESTful API URL中的动态参数。支持单个或多个路径变量,参数名一致时可省略value属性,不一致时需显式绑定,是构建清晰、语义化接口的关键注解之一。
|
SQL Java 数据库连接
Mybatis中强大的resultMap
Mybatis中强大的resultMap
556 0
|
Java Go Nacos
Spring Cloud Alibaba Nacos配置导入问题解决方案
Spring Cloud Alibaba Nacos配置导入问题解决方案
2894 0
|
5月前
|
JSON 前端开发 Java
Spring Boot 中的 @RequestMapping 与快捷映射注解
`@RequestMapping` 是 Spring MVC 中用于映射 HTTP 请求路径与处理方法的核心注解,可标注在类或方法上。类上使用定义公共前缀,方法上指定具体路径和请求方式。常用属性包括 `value`(路径)、`method`(请求类型)、`produces`(响应类型)。Spring 还提供了 `@GetMapping`、`@PostMapping` 等快捷注解,语义更清晰,推荐优先使用。
|
5月前
|
监控 前端开发 Java
Spring Boot 统一异常处理与全局响应增强
本文介绍如何在Spring Boot中实现全局异常处理,通过`@RestControllerAdvice`和自定义`BusinessException`统一拦截异常,结合`JsonResult`标准化响应格式,避免信息泄露,提升前后端协作效率与系统健壮性。
|
5月前
|
JSON 前端开发 Java
Spring Boot 返回 JSON 数据及数据封装
本课讲解Spring Boot中JSON处理:通过@RestController返回JSON,利用内置Jackson实现对象、List、Map自动序列化,并自定义配置优雅处理null值,提升前后端交互体验。
|
5月前
|
NoSQL Shell Linux
Windows 系统下的 MongoDB 单机部署
本文详细介绍 MongoDB 在 Windows 和 Linux 系统中的单机部署方法,涵盖下载安装、目录配置、服务启停、Shell 与 Compass 连接等步骤,助你快速搭建开发与生产环境。
|
Java 微服务 Spring
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——使用Logger在项目中打印日志
本文介绍了如何在项目中使用Logger打印日志。通过SLF4J和Logback,可设置不同日志级别(如DEBUG、INFO、WARN、ERROR)并支持占位符输出动态信息。示例代码展示了日志在控制器中的应用,说明了日志配置对问题排查的重要性。附课程源码下载链接供实践参考。
1415 0
|
11月前
|
存储 安全 前端开发
SpringBoot阿里云OSS文件上传实例
本文介绍了通过阿里云OSS实现用户头像上传的功能。首先概述了OSS的特点,如高持久性、RESTful API支持及多种存储类型。接着详细描述了前期准备步骤,包括注册阿里云账号、实名认证、开通OSS服务、创建Bucket及AccessKey。注意事项中提到需调整Bucket的访问权限以支持前端访问。最后提供了基于SpringBoot的代码实现,包含配置文件与上传工具类的编写,帮助开发者快速集成OSS文件上传功能。
2248 1
SpringBoot阿里云OSS文件上传实例
|
Java API Spring
Spring Boot中的 6 种API请求参数读取方式
本文介绍了Spring Boot中6种常见的请求参数读取方式:@RequestParam用于加载URL查询参数,@PathVariable处理RESTful风格的URL路径参数,@MatrixVariable处理URL路径中的矩阵变量,@RequestBody用于读取POST/PUT请求的复杂请求体,@RequestHeader加载请求头信息,而@CookieValue则用于获取Cookie值。这些注解在不同场景下满足了API参数的多样化需求。
378 6

热门文章

最新文章