4--SpringBootWeb-请求响应

目录

postman

1.简单参数

请求参数名与形参变量名一致时

请求参数名与形参变量名不一致时

2.实体参数

简单实体对象

复杂实体对象

3.数组集合参数

数组

集合

4.日期参数

5.JSON参数

6.路径参数

1

2


postman

Postman值一款功能强大的网页调试与发送网页HTTP请求的Chrome插件

作用:常用于进行接口测试

1.简单参数

定义方法形参,请求参数名与形参变量名一致,如果不一致,通过@RequestParam手动映射。

请求参数名与形参变量名一致时

控制台返回得到:tom:30

请求参数名与形参变量名不一致时

控制台返回null:30

因为请求参数名与形参变量名不一致,username和name

解决办法:使用@RequestParam手动映射

注意:@RequestParam中的required属性默认为true,代表该请求参数必须传递,如果不传递将报错。如果该参数是可选的,可以将required属性设置为false。

重新发送请求

控制台得到:tom:30

2.实体参数

请求参数名,与实体对象的属性名一样,会自动接收封装

简单实体对象

User中代码为:

package org.example.springboot2.pojo;

public class User {
    private String name;
    private Integer age;

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

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public Integer getAge() {
        return age;
    }

    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }
}

控制台得到

复杂实体对象

 请求参数名与形参对象属性名相同,按照对象的层次结构关系即可接收嵌套POJO属性参数

Address中代码为

package org.example.springboot2.pojo;

public class Address {
    private String province;
    private String city;

    @Override
    public String toString() {
        return "Address{" +
                "province='" + province + '\'' +
                ", city='" + city + '\'' +
                '}';
    }
    public String getProvince() {
        return province;
    }

    public void setProvince(String province) {
        this.province = province;
    }

    public String getCity() {
        return city;
    }

    public void setCity(String city) {
        this.city = city;
    }


}

并将User中代码改为

package org.example.springboot2.pojo;
import org.example.springboot2.pojo.Address;

public class User {
    private String name;
    private Integer age;
    private Address address;


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

    public void setAge(Integer age) {
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public Integer getAge() {
        return age;
    }

    public Address getAddress() {
        return address;
    }

    public void setAddress(Address address) {
        this.address = address;
    }


    @Override
    public String toString() {
        return "User{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", address=" + address +
                '}';
    }
}

在RequestController中增加代码:

控制台得到

3.数组集合参数

数组

数组:请求参数名与数组名一致,直接封装

数组参数:请求参数名与形参数组名称相同且请求参数为多个,定义数组类型形参即可接收数据

加入以下代码

//3.数组集合参数
    @RequestMapping("/arrayParam")
    public String arrayParam(String[] hobby){
        System.out.println(Arrays.toString(hobby));
        return "OK";
    }

控制台显示

集合

集合:请求参数名与集合名一致,@RequestParam绑定关系

增加以下代码

 @RequestMapping("/listParam")
    public String listParam(@RequestParam List<String> hobby){
        System.out.println(hobby);
        return "OK";
    }

控制台显示得到

4.日期参数

日期参数:使用@DateTimeFormat注解完成日期参数格式转换

增加代码如下

 //4.日期事件参数
    @RequestMapping("/dateParam")
    public String dateParam(@DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss")LocalDateTime updateTime){
        System.out.println(updateTime);
        return "OK";
    }

在控制台显示

5.JSON参数

JSON数据键名与形参对象属性名相同,定义POJO类型形参即可接收参数,需要使用@RequestBody

增加以下代码:

//5.JSON参数
    @RequestMapping("/jsonParam")
    public String jsonParam(@RequestBody User user){
        System.out.println(user);
        return "OK";
    }

在控制台显示

6.路径参数

通过请求URL直接传递参数,使用{...}来标识该路径参数,需要使用@PathVariable获取路径参数

1

增加以下代码

//6.路径参数
    @RequestMapping("/path/{id}")
    public String pathParam(@PathVariable Integer id){
        System.out.println(id);
        return "OK";
    }

控制台显示

 

控制台显示

2

增加以下代码

 @RequestMapping("/path/{id}/{name}")
    public String pathParam2(@PathVariable Integer id,@PathVariable String name){
        System.out.println(id);
        System.out.println(name);
        return "OK";
    }

控制台显示

控制台显示

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值