详细分析Java中的@RequestParam和@RequestBody

这篇具有很好参考价值的文章主要介绍了详细分析Java中的@RequestParam和@RequestBody。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

前言

该知识点主要来源于SpringMVC:SpringMVC从入门到精通(全)

慢慢作为一名全栈,偶尔看项目使用@RequestParam或者@RequestBody,对此需要做一个深度的总结,防止混淆

1. 基本知识

@RequestParam注解用于从HTTP请求中提取查询参数或表单参数。

其中一些常用的属性参数包括namedefaultValuerequired

下面是对这三个属性参数的详细解释:

  • name属性:用于指定要提取的查询参数或表单参数的名称
  • defaultValue属性:用于设置参数的默认值。(请求中没有提供相应的参数,将使用默认值)
  • required属性:用于指定参数是否是必需的
    设置为 true,则请求中必须包含相应的参数
    设置为 false,则参数是可选的
@GetMapping("/example")
public String exampleMethod(@RequestParam(name = "param",  defaultValue = "default", required = true) String param) {
    // Method implementation
}

@RequestBody注解用于从请求体中获取数据。

主要用于处理HTTP请求的请求体,通常用于接收JSON或XML格式的数据。

接收JSON数据: 通常用于接收通过POST请求发送的JSON数据

@PostMapping("/example")
public String exampleMethod(@RequestBody ExampleDto exampleDto) {
    // Method implementation
}

其中自定义的对象如下:( 通常与自定义的Java对象结合使用,Spring将尝试将请求体映射到该对象。)

public class ExampleDto {
    private String field1;
    private int field2;
    
    // Getters and setters
}

其他数据格式: 除了JSON,@RequestBody也可以处理其他格式的数据,例如XML

@PostMapping("/example")
public String exampleMethod(@RequestBody String xmlData) {
    // Method implementation
}

使用@RequestParam注解时更加灵活地处理查询参数或表单参数。

可以根据具体的需求,指定参数名、设置默认值以及确定参数是否是必需的

2. 使用场景

主要分析以下两种注解的常用形式,以及接口测试中是如何测试的

2.1 @RequestParam注解

  1. 处理查询参数:(处理HTTP GET请求中的查询参数)
    当客户端通过URL传递参数时,可以使用@RequestParam将这些参数映射到方法的参数中。
@GetMapping("/search")
public ResponseEntity<String> search(@RequestParam(name = "query") String query) {
    // Method implementation
}
  1. 处理表单参数:(通常用于处理HTTP POST请求中的表单数据)
    当客户端通过表单提交数据时,可以使用@RequestParam将表单参数映射到方法的参数中。
@PostMapping("/submitForm")
public ResponseEntity<String> submitForm(@RequestParam(name = "username") String username, 
                                        @RequestParam(name = "password") String password) {
    // Method implementation
}
  1. 设置默认值
    使用@RequestParam可以为参数设置默认值,当请求中没有提供相应的参数时,将使用默认值。
@GetMapping("/example")
public ResponseEntity<String> example(@RequestParam(name = "param", defaultValue = "default") String param) {
    // Method implementation
}
  1. 接收多个参数
    @RequestParam允许接收多个参数,并将它们映射到方法的多个参数中。可以通过多次使用该注解来处理多个参数。
@GetMapping("/multipleParams")
public ResponseEntity<String> multipleParams(@RequestParam(name = "param1") String param1,
                                            @RequestParam(name = "param2") int param2) {
    // Method implementation
}

2.2 @RequestBody注解

  • 处理非表单数据
    @RequestBody适用于处理非表单格式的数据,例如JSON、XML等。当请求的数据不是通过表单提交,而是通过请求体中的结构化数据传递时,可以使用该注解。
// createObject方法接收的是一个自定义对象 MyObject,该对象的数据可以通过请求体中的JSON数据进行填充
@PostMapping("/create")
public ResponseEntity<String> createObject(@RequestBody MyObject myObject) {
    // Method implementation
}
  • 接收复杂对象:(自动将请求体中的数据映射为方法参数所需的对象,无需手动解析)
    当需要接收复杂的Java对象或自定义的数据结构时,使用@RequestBody更为方便
//updateObject方法接收的是一个包含更新数据的自定义请求对象 UpdateObjectRequest
@PostMapping("/update")
public ResponseEntity<String> updateObject(@RequestBody UpdateObjectRequest request) {
    // Method implementation
}
  • 处理RESTful API请求:(@RequestBody使得处理这种情况变得更加简便)
    需要从请求体中获取数据进行资源的创建、更新或其他操作
//updateResource方法接收的是路径中的资源标识符以及请求体中的数据
@PutMapping("/update/{id}")
public ResponseEntity<String> updateResource(@PathVariable Long id, @RequestBody ResourceData data) {
    // Method implementation
}
  • 支持多种数据格式:(后端服务可以根据实际需求选择最适合的数据格式)
    @RequestBody不限于特定的数据格式,因此可以支持多种数据格式的传递,包括JSON、XML等
//processData方法可以接收不同格式的数据对象,根据实际请求体中的数据格式进行处理
@PostMapping("/process")
public ResponseEntity<String> processData(@RequestBody DataObject data) {
    // Method implementation
}

3. 接口测试

3.1 @RequestBody注解

  • POST获取的接口都是带有参数的,此处的参数为String
    测试代码如下:

@requestparam,Java,java,RequestBody,RequestParam

对应的接口测试可以选择 Params 或者 Body 中的 x-www-form-urlencoded

@requestparam,Java,java,RequestBody,RequestParam

或者如下图:
(由于删除功能此处做了逻辑删除,博主在后台改了属性又恢复回来了!)
对应的逻辑删除可看这篇文章:详细讲解MybatisPlus实现逻辑删除

@requestparam,Java,java,RequestBody,RequestParam

3.2 @RequestBody注解

代码示例如下:

@requestparam,Java,java,RequestBody,RequestParam

对于Apipost的测试软件,大致如下界面:

@requestparam,Java,java,RequestBody,RequestParam

对于PostMan的测试接口界面如下,截图如下,对应需要选择raw中的Json格式,才可测试成功:(由于是下载Excel,对应会有乱码, 但是返回值为200)

@requestparam,Java,java,RequestBody,RequestParam

4. 总结

  1. @RequestParam适用于处理HTTP请求中的查询参数和表单参数,以及在需要设置默认值、接收多个参数的情况下使用。这使得在Spring MVC应用中,处理简单的参数传递变得更加方便。

  2. @RequestBody注解适用于接收请求体中的结构化数据,特别是在处理非表单数据、接收复杂对象、处理RESTful API请求以及支持多种数据格式的情况下。
    (一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/jsonapplication/xml等类型的数据)

注意:前端使用$.ajax的话,一定要指定 contentType: "application/json;charset=utf-8;",默认为 application/x-www-form-urlencoded文章来源地址https://www.toymoban.com/news/detail-858312.html

到了这里,关于详细分析Java中的@RequestParam和@RequestBody的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • @RequestParam @RequestBody @PathVariable用法详解

    三个注解都是在我们进行请求时对服务端参数进行封装的,那么具体三个注解的使用,什么情况下,什么条件下使用呢? @RequestParam接收的参数是来自于RequestHeader中,即请求头。 @RequestParam用来处理 Content-Type 为 application/x-www-form-urlencoded 编码的内容,Content-Type默认为该属性。

    2024年02月13日
    浏览(45)
  • Postman测试@RequestBody和@RequestParam参数案例

    Postman是一款强大的接口测试工具。 代码如下(示例): 个人感觉 flag 字段放到 StudentScore 对象中会比较方便处理; 回到顶部

    2024年02月15日
    浏览(44)
  • @RequestBody,@RequestParam,@RequestPart应用场景和区别

    使用此注解接收参数时,适用于请求体格式为 application/json,只能用 对象接收 支持application/json,也同样支持multipart/form-data请求 @RequestPart 这个注解用在 multipart/form-data 表单提交请求的方法上。 支持的请求方法的方式 MultipartFile ,属于Spring的 MultipartResolver 类。这个请求是通过

    2024年02月04日
    浏览(43)
  • 深入剖析@RequestBody、@PathVariable和@RequestParam注解

    当我们在开发服务端方法时,遇到给方法传参的有几个不同的注解,今天我们来介绍 @RequestBody 、 @PathVariable 和 @RequestParam 这几个注解的定义和使用场景示例,以便于同学们理解和掌握。 @RequestBody 注解: 定义: @RequestBody 注解用于从请求体中获取数据,并将其转换为指定的对

    2024年02月09日
    浏览(36)
  • postman测试常用 5种传参类型,@RequestBody、@RequestParam、@PathVariable区别

    开启自动转换JSON数据的支持 @EnableWebMVC 请求json参数: 区别: @RequestParam用于接收url地址传参,表单传参【application/x-www-form-urlencoded】 @RequestBody用于接收json数据【application/json】 应用: 发送json格式数据为主,@RequestBody 非发送json格式数据为主,@RequestParam 定义传参的日期格式

    2024年02月09日
    浏览(53)
  • 搞清楚@RequestBody和@RequestParam的异同,让你的面试不再被问倒!

    大家好,我是小米。今天我要给大家分享一个常见的面试题:“@RequestBody和@RequestParam之间有什么区别?”这个问题在Java Web开发中非常常见,对于初学者来说可能会有些混淆。那么,让我们一起来揭开这个谜团,深入了解这两者之间的区别吧! 在Spring框架中,@RequestBody和@R

    2024年02月15日
    浏览(49)
  • 前端传递对象参数,以及后端接受参数 @PathVariable @RequestParam @RequestBody 注解的使用

    太久没写前后端传递参数了,总是格式对不上号 提示:以下是本篇文章正文内容,下面案例可供参考 拼接在 url 地址中的 后端 前端 api 调用请求 拼接在 url 地址后面的 后端 前端 api 调用请求 放在请求头当中 后端 前端 api 调用请求 前端传递对象,后端接收对象 放在请求体中的

    2023年04月26日
    浏览(49)
  • PostMan、ApiFox等工具Post请求中@RequestParam和@RequestBody的混合使用如何传参

    方法签名 以ApiFox为例子 @RequestParam的Params的参数正常传参 @RequestBody的参数要以json的格式传输 同时Header中要指明 Content-Type=application/json 这样就OK了。 祝:工作顺利,永不加班,生活开心。

    2024年02月05日
    浏览(46)
  • Spring MVC的@RequestParam分析

    本篇文章涉及到一下相关问题 1.报错Required String parameter \\\'xx\\\' is not present 2.@RequestParam接收post请求参数报错 3.@RequestParam使用原理 4.springmvc使用@RequestParam一样的参数名,怎么接收不到。 5.axios发送post请求,springMVC接收不到数据问题 代码中是规定了请求方式 POST ,使用 @RequestPara

    2023年04月23日
    浏览(34)
  • 【踩坑日记】feign调用时报错:java.lang.IllegalStateException: RequestParam.value() was empty on parameter 0

    SpringCloud微服务,使用feign进行服务间的调用 服务启动后出现异常: IllegalStateException: RequestParam.value() was empty on parameter 0 非法状态异常。大概意思是:第 0 个参数绑定的 value 值为空。也就是说第 0 个参数没有正确的绑定请求的参数映射。 这个错误产生的原因是我们使用了

    2024年02月05日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包