postmapping注解参数说明_spring-boot如何去获取前端传递的参数?

本文主要讨论spring-boot如何获取前端传过来的参数,这些参数主要有两大类,一类是URL里的参数,一个是请求body里的参数

url里的参数

通过url里传过来的参数一般有三种方式,下面我们来看一下

  • 路径参数

路径参数就是说在请求路径里携带了几个参数,比如有一个查询banner详情的接口,/v2/banner/123,这里的123就是参数,可以表示banner的ID。

下面我们设计了一个简陋的接口,来演示路径参数的获取

@RestController
@RequestMapping(value = "/v2/banner")
public class BannerController {

    @GetMapping("/{id}")
    public Integer getBannerDetail(@PathVariable Integer id){
        return id;
    }
}

获取banner详情完整接口路径是/v2/banner/{id},这里的id就是路径参数,在方法的传参里,用@PathVariable注解标明那个参数用来接收请求路径传递过来的值,通过postman发个请求看看

e531c6d14d49e37d5465bfc0ed0a2eed.png

这里要注意,接口路由里定义的参数名要和方法参数里的定义名字要一样,如果不一样需要通过@PathVariable来指定**

@GetMapping("/{id}")
public Integer getBannerDetail(@PathVariable(name = "id") Integer id12){
    return id12;
}
  • 查询参数

查询参数就是请求的url里?号后面跟的键值对,比如/v2/banner?id=123,下面我们重新定义一个借口,采用查询参数的形式获取banner详情

e38b5ddcc30f6101ed832455e63189db.png

请求url里的查询参数通过@RequestParam注解可以和方法里的参数进行一一对应,比如现在有这么个url:/v2/banner?id=123&pos=3,那么接口的参数定义就得是@RequestParam Integer id, @RequestParam Integer pos,请求上面定义的接口看看返回值

b409e133aa06887afa87e2a9e335fec6.png
  • 路径参数和查询参数结合

路径参数和查询时可以同时使用的,那在定义接口的时候,同时使用这两种注解就行,比如下面的接口

@GetMapping("/{id}")
public Map<String, Object> getBannerDetail(@PathVariable Integer id, @RequestParam Integer pos){
    Map<String, Object> body = new HashMap<>();
    body.put("id", id);
    body.put("pos", pos);
    return body;
}

请求一下接口

2ee7e380b19e338b2030ab4bf0f2ea14.png

请求body里的参数

先来思考一个问题,当前端传递过来一个json的数据,我们的方法通过什么样的形式能够接受到参数呢?

一般来说有两种形式,Map和自定义对象,下面我们分别来介绍一下。

  • Map

设计简单的banner创建接口,参数通过Map来接收,创建成功后,添加一个id,然后将传递的数据和id一起返回

@PostMapping(value = "/create")
public Map<String, Object> createBanner(@RequestBody Map<String, Object> banner){
    banner.put("id", 1243);
    return banner;
}

这里@RequestBody的这个注解来将body里的参数,转化成一个map,请求一下接口看看正常不:

fb647ff606b69843b4e489a724241a40.png

上面我们使用的Map,它是一个接口,在具体接收数据的时候,肯定会用一个Map的实现类,这就会设计到装箱拆箱的过程,那么频繁的装箱拆箱会有一定到的性能损耗,所以这种方式一般并不推荐使用。

  • 自定义对象Dto

我们将接收请求参数的对象称作为数据传输对象,一般定义为XXXDto,这里我们定义一个创建banner时用来接收参数的对象BannerCreateDto.

public class BannerCreateDto {
    private String name;
    private Integer pos;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getPos() {
        return pos;
    }

    public void setPos(Integer pos) {
        this.pos = pos;
    }
}

在Controller具体使用:

@PostMapping(value = "/create")
public Map<String, Object> createBanner(@RequestBody BannerCreateDto dto){
    Map<String, Object> res = new HashMap<>();
    res.put("id", 10000);
    res.put("name", dto.getName());
    res.put("pos", dto.getPos());
    return res;
}

用@RequestBody标记BannerCreateDto对象,spring-boot会自动调用对象的getter和setter给他赋值。我们请求一下看看:

f536f77520d6127fada3355c4e2b123b.png

总结

以上就是我们对spring-boot进行参数接收时处理方式的讨论,包括路径参数以及查询参数,还有body参数的接收

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PostMapping是Spring MVC中的一个注解,它表示将HTTP POST请求映射到特定的处理程序方法上。 @PostMapping注解有以下参数: 1. value:表示要映射的URL路径。 2. consumes:表示接受请求的内容类型,可以是MediaType类型的值,也可以是多个值的数组。 3. produces:表示响应的内容类型,可以是MediaType类型的值,也可以是多个值的数组。 4. params:表示请求必须满足的参数条件,它是一个键值对数组,可以使用参数名称或者表达式。 5. headers:表示请求必须满足的头信息条件,它也是一个键值对数组,可以使用头信息名称或者表达式。 6. name:表示请求的名称。 7. path:表示请求的路径。 8. method:表示请求的方法,可以是RequestMethod类型的值,也可以是多个值的数组。 9. consumes、produces、params和headers这些参数都是可选的,可以根据具体的需求来选择。 示例: ``` @PostMapping(value="/user", consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE) public ResponseEntity<String> createUser(@RequestBody User user) { // 处理请求 } ``` 上面的示例中,@PostMapping注解将HTTP POST请求映射到"/user"路径,并且请求的内容类型是JSON类型,响应的内容类型也是JSON类型。同时,使用@RequestBody注解将请求中的JSON数据映射到User对象中。最终,处理完请求后返回ResponseEntity对象。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值