@RequestParam与@RequestBody对比

导读:本篇文章讲解 @RequestParam与@RequestBody对比,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com

handler method 参数绑定常用的注解,我们根据他们处理的Request的不同内容部分分为四类:(主要讲解常用类型)

  1. 处理requet uri 部分(这里指uri template中variable,不含queryString部分)的注解: @PathVariable;
  2. 处理request header部分的注解: @RequestHeader, @CookieValue;
  3. 处理request body部分的注解:@RequestParam, @RequestBody;
  4. 处理attribute类型是注解: @SessionAttributes, @ModelAttribute;

本文只讨论:@RequestParam和@RequestBody。

1、根据content-type方面区分:

  1. application/json:json字符串部分可以用@RequestBody;url中的?后面参数可以用@RequestParam。见下图
    在这里插入图片描述

  2. form-data、x-www-form-urlencoded:不可以用@RequestBody;可以用@RequestParam。
    如果用@RequestBody,值会合并在一起。如下图所示。在这里插入图片描述
    在这里插入图片描述
    所以这样还是需要后台代码再去解析一次,注解等于无效。
    正确的:
    在这里插入图片描述

2、根据注解方式区分:

  • @RequestBody
    该注解常用来处理Content-Type为application/json, application/xml的数据;

(@RequestBody Map map)
(@RequestBody Object object)
application/json时候可用
form-data、x-www-form-urlencoded时候不可用

ps:

  1. GET请求不能用@RequestBody来接收参数。
  2. 后台只能有一个@Request注解
  • @RequestParam
    使用@RequestParm用于绑定controller上的参数,可以是多个参数,也可以是一个Map集合,GET,POST均可

(@RequestParam Map map)
application/json时候,json字符串部分不可用,url中的?后面添加参数即可用,见图一
form-data、x-www-form-urlencoded时候可用,但是要将Headers里的Content-Type删掉

(@RequestParam String param1,
@RequestParam String param2)
application/json时候,json字符串部分不可用,url中的?后面添加参数即可用。

form-data、x-www-form-urlencoded时候可用,且参数可以没有顺序(即前端传过来的参数或者url中的参数顺序不必和后台接口中的参数顺序一致,只要字段名相同就可以),但是要将Headers里的Content-Type删掉

(@RequestParam Object object)
不管application/json、form-data、x-www-form-urlencoded都不可用

ps:只支持Content-Type: 为 application/x-www-form-urlencoded编码的内容。Http协议中,如果不指定Content-Type,则默认传递的参数就是application/x-www-form-urlencoded类型)


注解对比图

区别 @RequestParam @RequestBody
content-type 仅支持x-www-form-urlencoded json(常用), xml
请求类型 所有 除了GET
注解个数 可多个 只能有一个


  • 文章是个人知识点整理总结,如有错误和不足之处欢迎指正。
  • 如有疑问、或希望与笔者探讨技术问题(包括但不限于本章内容),欢迎添加笔者微信(o815441)。请备注“探讨技术问题”。欢迎交流、一起进步。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/69857.html

(0)
小半的头像小半

相关推荐

极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!