`
wx1568905209
  • 浏览: 25168 次
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

注解@RequestParam与@RequestBody的使用场景

 
阅读更多

一、前言

一直有这么一个疑问:在使用postman工具测试api接口的时候,如何使用 json 字符串传值呢,而不是使用 x-www-form-urlencoded 类型,毕竟通过 key-value 传值是有局限性的。假如我要测试批量插入数据的接口呢,使用 x-www-form-urlencoded 方法根本就不适用于这种场景。

那么如何通过postman工具使用json字符串传值呢,这里就引申出来了spring的两个注解:

  • @RequestParam
  • @RequestBody

总而言之,这两个注解都可以在后台接收参数,但是使用场景不一样。继续往下看 ↓

二、@RequestParam

先介绍一下@RequestParam的使用场景:

注解@RequestParam接收的参数是来自requestHeader中,即请求头通常用于GET请求,比如常见的url:http://localhost:8081/spring-boot-study/novel/findByAuthorAndType?author=唐家三少&type=已完结,其在Controller 层的写法如下图所示:

1620

@RequestParam有三个配置参数:

  • required 表示是否必须,默认为 true,必须。
  • defaultValue 可设置请求参数的默认值。
  • value 为接收url的参数名(相当于key值)。

@RequestParam用来处理 Content-Typeapplication/x-www-form-urlencoded 编码的内容,Content-Type默认为该属性。

@RequestParam也可用于其它类型的请求,例如:POST、DELETE等请求。比如向表中插入单条数据,Controller 层的写法如下图所示:

1620

由于@RequestParam是用来处理 Content-Typeapplication/x-www-form-urlencoded 编码的内容的,所以在postman中,要选择body的类型为 x-www-form-urlencoded,这样在headers中就自动变为了 Content-Type : application/x-www-form-urlencoded 编码格式。如下图所示:

1620

但是这样不支持批量插入数据啊,如果改用 json 字符串来传值的话,类型设置为 application/json,点击发送的话,会报错,后台接收不到值,为 null

这时候,注解@RequestBody就派上用场了。继续往下看 ↓

三、@RequestBody

先介绍一下@RequestBody的使用场景:

注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/jsonapplication/xml等类型的数据。

application/json类型的数据而言,使用注解@RequestBody可以将body里面所有的json数据传到后端,后端再进行解析。

3.1 向表中批量插入数据

举个批量插入数据的例子,Controller层的写法如下图所示:

1620

由于@RequestBody可用来处理 Content-Typeapplication/json 编码的内容,所以在postman中,选择body的类型为row -> JSON(application/json),这样在 Headers 中也会自动变为 Content-Type : application/json 编码格式。body内的数据如下图所示:

1620

批量向表中插入两条数据,这里的 saveBatchNovel()方法已经封装了 JPAsaveAll() 方法。body 里面的 json 语句的 key 值要与后端实体类的属性一一对应。

注意:前端使用$.ajax的话,一定要指定 contentType: "application/json;charset=utf-8;",默认为 application/x-www-form-urlencoded

3.2 后端解析json数据

上述示例是传递到实体类中的具体写法,那么如果传递到非实体类中,body里面的json数据需要怎么解析呢?我们再来看下面这个例子:

在body中,我们还是输入上面的json数据,根据分析,上面的json数据是一个List数组内嵌套着map对象,那么在后台的接收形式可写为 List<Map<String, String>>,具体代码如下图所示:

1620

postman请求:

1620

控制台输出:

1620

得出结论,通过@RequestBody可以解析Body中json格式的数据。

四、总结

注解@RequestParam接收的参数是来自requestHeader中,即请求头通常用于GET请求,像POST、DELETE等其它类型的请求也可以使用。

注解@RequestBody接收的参数是来自requestBody中,即请求体。一般用于处理非 Content-Type: application/x-www-form-urlencoded编码格式的数据,比如:application/jsonapplication/xml等类型的数据。通常用于接收POST、DELETE等类型的请求数据,GET类型也可以适用。

转载于:https://my.oschina.net/u/2277392/blog/3102157

分享到:
评论

相关推荐

    springMVC的 RequestBody和 ResponseBody和RequestParam.docx

    在 Spring MVC 中,请求参数的处理非常灵活,可以使用 `@RequestParam`、`@RequestBody` 和 `@ResponseBody` 等注解进行数据绑定和响应体的控制。 #### 二、`@RequestBody` `@RequestBody` 注解通常用于控制器中的...

    SpringMVC中使用@RequestBody,@ResponseBody注解实现Java对象和XML/JSON数据自动转换(上)

    在实际开发中,`@RequestBody` 和 `@ResponseBody` 的组合使用使得Spring MVC能够轻松地处理RESTful API的请求和响应。它们简化了数据交换的过程,减少了手动序列化和反序列化的代码,提高了开发效率。通过理解这两...

    Spring 注解学习手札(二) 控制层梳理

    六、@RequestBody和@ResponseBody注解 这两个注解配合使用,可以将HTTP请求体中的数据自动转换为Java对象,或者将方法返回的对象转换为HTTP响应体。@RequestBody用于接收POST请求中的JSON或XML数据,而@ResponseBody...

    SpringCloud Feign服务调用请求方式总结

    POST请求可以使用@RequestBody注解和@RequestParam注解,例如: @RequestMapping(value = "/moreArgs/postDemo") public void moreArgPostDemo(@RequestBody String name, @RequestParam String sex); 也可以全部...

    SpringBoot前后端传值.docx

    - `application/json` 或 `application/xml`:必须使用 `@RequestBody` 来处理,URL 中的参数仍可用 `@RequestParam` 接收。 #### 实际运用 - **参数传值**:当使用 form 表单参数或 URL 参数时,可以直接使用...

    springmvc注解详解

    `@RequestBody` 注解用于将请求体的内容映射到方法参数上,通常用于接收 JSON 或 XML 数据。Spring MVC 自动将请求体的内容转换为指定的对象类型。 ### 7. `@ResponseBody` `@ResponseBody` 注解用于将方法返回的...

    springMVC接收参数的几种注解.pdf

    如果参数名与 URI 模板中的变量名不一致,可以使用 `@PathVariable("name")` 指定变量名。 2. **@RequestHeader 和 @CookieValue** `@RequestHeader` 注解允许开发者从 HTTP 请求头中获取值并将其绑定到方法参数...

    springMVC注解大全

    13. `@RequestBody`:用于将HTTP请求体的数据(通常是JSON或XML)转换为Java对象。 14. `@ResponseEntity`:与`@ResponseBody`类似,但提供了更多的HTTP响应控制,如状态码、头部信息等。 以上就是Spring MVC中...

    SpringMVC中注解的详细使用

    6. `@RequestBody`:用于将请求体(通常是JSON或XML)转换为Java对象。这在接收复杂数据结构时非常有用。 7. `@ResponseBody`:将方法返回的对象直接序列化为HTTP响应体,而不是渲染到视图。这常用于返回JSON或XML...

    spring注解实例

    7. `@RequestParam`、`@PathVariable`、`@RequestHeader` 和 `@RequestBody`:这些注解用于从HTTP请求中提取参数。 8. `@Transactional`:标记方法为事务性的,Spring会自动管理事务边界。 接下来,SSH2中的Spring...

    ssm纯注解配置例子.rar

    `@PathVariable`、`@RequestParam`、`@RequestHeader`和`@RequestBody`则用于处理请求参数。此外,`@Controller`类中的方法通常会使用`@ResponseBody`注解,将返回值直接转换为HTTP响应体。 MyBatis的注解配置主要...

    Springmvc请求处理方法参数

    通过`@RequestBody`注解,我们可以将JSON数据自动绑定到Java对象上。 ```java @RequestMapping(method = RequestMethod.POST) public ResponseEntity createUser(@RequestBody User user) { // ... } ``` ### 8. ...

    SpringMVC接收请求参数区别.docx

    在Spring MVC中,接收请求参数有多种方式,包括@RequestParam、@PathVariable、@RequestBody以及@ModelAttribute。这些注解各自适用于不同的场景,并且与HTTP请求的方法(GET、POST等)和Content-Type紧密相关。以下...

    spring boot开发前后端注意事项

    在Spring Boot中,我们可以通过@RequestBody注解接收JSON格式的数据。后端会解析请求体中的JSON数据,并将其转换为相应的Java对象。在前端发送JSON数据前,可以使用JSON.stringify()方法进行格式化。 在使用URL路径...

    spring mvc4中相关注解的详细讲解教程

    在本教程中,我们将深入探讨几个关键的注解,包括@Controller、@RequestMapping、@PathVariable、@RequestParam和@RequestBody,这些都是Spring MVC4中实现请求处理的关键元素。 1. **@Controller** `@Controller`...

    Spring MVC传值

    可以使用`@RequestBody`注解将请求体内容映射到Java对象: ```java @PostMapping("/user") public String createUser(@RequestBody User user) { // 处理逻辑... } ``` 2. **Multipart请求**:用于上传文件...

    SpringBoot注解文档

    14. `@RequestBody`和`@ResponseBody`: 分别用于将HTTP请求体转换为Java对象,以及将Java对象转换为HTTP响应体。 15. `@RequestParam`和`@PathVariable`: 分别用于从URL参数和路径变量中获取值。 16. `@...

    Spring MVC之Controller层的常用注解

    6. `@RequestBody`:用于读取请求体中的数据,通常用于POST、PUT等带有请求体的HTTP操作。它可以与任何POJO类型结合,将请求体转换为Java对象。 7. `@ResponseBody`:表示方法的返回值将直接写入HTTP响应体,而非...

    springmvc注解方式

    这里 `@GetMapping` 处理获取物品列表的请求,而 `@PostMapping` 处理创建新物品的请求,`@RequestBody` 注解用于将请求体中的 JSON 数据映射到 `Item` 对象。 4. `@RequestParam`:用于从请求参数中获取值。例如...

Global site tag (gtag.js) - Google Analytics