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 表单和查询接口的常用方式。


相关文章
|
4月前
|
Java API Spring
Spring Boot 中的 @PathVariable:获取 RESTful 路径参数
在Spring Boot中,`@PathVariable`用于提取RESTful API URL中的动态参数。支持单个或多个路径变量,参数名一致时可省略value属性,不一致时需显式绑定,是构建清晰、语义化接口的关键注解之一。
|
4月前
|
JSON 前端开发 Java
Spring Boot 中的 @RequestMapping 与快捷映射注解
`@RequestMapping` 是 Spring MVC 中用于映射 HTTP 请求路径与处理方法的核心注解,可标注在类或方法上。类上使用定义公共前缀,方法上指定具体路径和请求方式。常用属性包括 `value`(路径)、`method`(请求类型)、`produces`(响应类型)。Spring 还提供了 `@GetMapping`、`@PostMapping` 等快捷注解,语义更清晰,推荐优先使用。
|
4月前
|
监控 前端开发 Java
Spring Boot 统一异常处理与全局响应增强
本文介绍如何在Spring Boot中实现全局异常处理,通过`@RestControllerAdvice`和自定义`BusinessException`统一拦截异常,结合`JsonResult`标准化响应格式,避免信息泄露,提升前后端协作效率与系统健壮性。
|
4月前
|
XML Java 数据格式
Spring @Configuration 注解详解:用 Java 代码替代 XML 配置
`@Configuration` 是 Spring 实现 Java 配置的核心注解,替代传统 XML,通过 `@Bean` 注册 Bean,结合 `@Import`、`@ComponentScan` 等实现类型安全、可维护的配置方式,推动 Spring 应用现代化。
|
4月前
|
JSON 前端开发 Java
Spring Boot 返回 JSON 数据及数据封装
本课讲解Spring Boot中JSON处理:通过@RestController返回JSON,利用内置Jackson实现对象、List、Map自动序列化,并自定义配置优雅处理null值,提升前后端交互体验。
|
4月前
|
JSON 前端开发 安全
用自定义注解 + 拦截器实现登录鉴权
通过自定义注解 `@Login` 结合 Spring 拦截器,实现声明式登录校验。无需重复编码,自动拦截未登录请求,提升代码可维护性与安全性,适用于前后端分离架构的权限控制实践。
|
4月前
|
NoSQL Shell Linux
Windows 系统下的 MongoDB 单机部署
本文详细介绍 MongoDB 在 Windows 和 Linux 系统中的单机部署方法,涵盖下载安装、目录配置、服务启停、Shell 与 Compass 连接等步骤,助你快速搭建开发与生产环境。
|
Java 微服务 Spring
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录——使用Logger在项目中打印日志
本文介绍了如何在项目中使用Logger打印日志。通过SLF4J和Logback,可设置不同日志级别(如DEBUG、INFO、WARN、ERROR)并支持占位符输出动态信息。示例代码展示了日志在控制器中的应用,说明了日志配置对问题排查的重要性。附课程源码下载链接供实践参考。
1324 0
|
10月前
|
存储 安全 前端开发
SpringBoot阿里云OSS文件上传实例
本文介绍了通过阿里云OSS实现用户头像上传的功能。首先概述了OSS的特点,如高持久性、RESTful API支持及多种存储类型。接着详细描述了前期准备步骤,包括注册阿里云账号、实名认证、开通OSS服务、创建Bucket及AccessKey。注意事项中提到需调整Bucket的访问权限以支持前端访问。最后提供了基于SpringBoot的代码实现,包含配置文件与上传工具类的编写,帮助开发者快速集成OSS文件上传功能。
2043 1
SpringBoot阿里云OSS文件上传实例
|
9月前
|
监控 安全 NoSQL
【SpringBoot】OAuth 2.0 授权码模式 + JWT 令牌自动续签 的终极落地指南,包含 深度技术细节、生产环境配置、安全加固方案 和 全链路监控
【SpringBoot】OAuth 2.0 授权码模式 + JWT 令牌自动续签 的终极落地指南,包含 深度技术细节、生产环境配置、安全加固方案 和 全链路监控
3100 1