api中@RequestBody,@RequestParam,@PathParam,@PathVariable获取参数

1.@RequestParam与@PathVariable以及@PathParam的区别

 @GetMapping("/data/reqparam/{id}")
    // @RequestParam 可以设置参数是否为必须传,以及默认值
    // URL:xxxx/shop/data/reqparam/1?id=2
    public String dataTest(@RequestParam(value="id",defaultValue = "2",required = true) String id) {

        return id;
    }

    @GetMapping("/data/pathparam/{param}")
    // 获取参数同@RequestParam
    // URL:xxxx/shop/data/pathparam/1?param=2
    public String dateTest3(@PathParam(value="param") String param) {
        return param;
    }

    @GetMapping("/data/pathvar/{name}")
    // URL:xxxx/shop/data/pathvar/1
    public String dateTest2(@PathVariable(value="name",required = true) String name) {
        return name;
    }

2.@RequestBody获取参数

参考文章:https://juejin.im/post/5b5efff0e51d45198469acea

2.1使用@RequestBody的时候,api的接口大多是post方式,这时候处理的headers中content-type,不是默认的application/x-www-form-urlencoded请求方式,而是application/json或者是application/xml等请求方式

当使用application/x-www-form-urlencoded时:

Content type 'application/x-www-form-urlencoded;charset=UTF-8' not supported

其实想用这个参数的本意是,想用一个Map<String,Object>接收前台传过来的所有数据。

 @PostMapping("/date/all")
    public String getAllDate(@RequestBody Map<String, Object> map) {

        return "success";
    }

这里使用强大的postman来进行测试

对应控制台在debug模式下的参数为:

 这里可以看到,用Map接收到了前台传给后台的所有数据,再对我们想要处理的数据进行处理。

2.2当然,我们也可以直接用一个DTO类(面向对象的思想,本人习惯将前后台进行传输的数据封装成DTO类,方便数据的传输,以及减少数据的冗余)来接收前台传给我们的数据。

@RequestMapping(value = "/data/dto/all",method = {RequestMethod.POST,RequestMethod.GET})
public String getDTOAll(ReqDTO reqDTO) {

    return "success";
}

这里以GET/POST方式都能获取到前台传到后台的参数(注意:如果前台传了DTO独享中不存在的成员,则后台接收不到该数据)

 

GET方式:

POST方式

这里需要注意,当使用POST方式的时候headers的content-type的请求方式,和@RequestBody的不同,这里要使用:

application/x-www-from-urlencoded请求方式。

写的不好,希望能帮助大家,有什么问题还望大家多多指出。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
@RequestBody、@PathVariable和@RequestParam是Spring MVC框架常用的注解,用于处理请求参数的传递和接收。 - @RequestBody注解表示请求参数将被解析为请求的JSON数据,并绑定到方法参数上。通常在后期开发,当发送的请求参数超过一个时,推荐使用@RequestBody注解处理。示例代码如下: ```java @PostMapping public R<String> save(@RequestBody DishDto dishDto) { dishService.saveWithFlavor(dishDto); return R.success("菜品添加成功"); } ``` - @PathVariable注解用于接收请求路径的变量值。通常在使用RESTful风格进行开发时,当参数数量较少时,可以使用@PathVariable注解来传递id值。示例URL格式如下: ``` http://localhost:8080/dish/1552978624443916290/zhangsan ``` - @RequestParam注解用于接收请求参数。如果发送的是非JSON格式的数据,可以选用@RequestParam注解接收请求参数。示例URL格式如下: ``` http://localhost:8080/dish?ids=1552978624443916290 ``` 需要注意的是,在GET请求,可以使用@PathVariable和@RequestParam注解,但不可以使用@RequestBody注解,因为GET请求没有请求体。而在POST请求,@RequestBody接收的是JSON数据,@RequestParam接收的是form表单提交的数据。 此外,需要明确的是,在一个方法,@PathVariable和@RequestParam可以使用多次,但@RequestBody只能使用一次。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [@RequestBody、@PathVariable、@RequestParam三个注解用法与区别](https://blog.csdn.net/zqm1992409670/article/details/126136819)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值