java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > SpringBoot中rest接口定义与参数传递和接收

SpringBoot项目中rest接口定义与参数传递和接收方式

作者:撞撞~

本文介绍了使用RestClient测试接口的两种方式:form-data和content-type,form-data适用于所有请求方式,但URL长度有限制,content-type只适用于POST/DELETE/PUT请求,处理application/json格式参数,对于参数较多的情况,建议使用JavaBean接收

建议使用rest Client测试接口

方式一:form-data形式

参数以key-value形式传递,参数和值会直接拼接到请求url后边显示存在(POST http://localhost:8080/users/insert?id=5&userName=刘明);

适用于所有请求方式;

后台接收参数时使用注解@RequestParam

POST

提交资源时一般post请求方式,当然所有的增删改也可已使用post请求

使用@RequestParam(value = “key”) 绑定请求参数到方法入参时,参数名可以不与前台key一致

@RestController
@RequestMapping("/users")
public class UsersController {
    @PostMapping("/insert")
    public RestResult insertUserInfo(@RequestParam("userId") int id, String userName, String passWord, int age,String sex, String phone) {...}
}

请求参数可以这样显示接收,也可以从 request 中获取

insertUserInfo(HttpServletRequest request) {
        String userId = request.getParameter("userId");
        String phone = request.getParameter("phone");
		...
}

如果请求参数为定义的对象属性时,可以直接使用对象接收参数

public class User {
    private int id;
    private String userName;
    private String passWord;
    private int age;
    private String sex;
    private String phone;
}
@PostMapping("/insert")
    public RestResult insertUserInfo(User user) {...}

DELETE

删除资源

使用@PathVariable 获取url路径中的参数

@DeleteMapping("/delete/{id}")
public RestResult deleteUser(@PathVariable("id") int userId) {...}

PUT

更新资源

@PutMapping("/update/{id}")
public RestResult updateUser(@PathVariable int id, String phone) {...}

GET

获取资源

@GetMapping("/query/{id}")
    public RestResult queryUser(@PathVariable int id) {...}

方式二、content-type形式

因为GET请求头中无content-type字段,所以此种方式只适用于POST/DELETE/PUT请求,用来处理:applicatin/json格式的参数

参数以json形式传递,后台获取参数时使用注解@RequestBody

@PostMapping("/insert")
    public RestResult insertUserInfo(@RequestBody User user) {...}

我们也可以使用@JsonProperty 注解来绑定Json中的key和Bean实体的属性

这时候,前台在传递参数时,可以使用与属性名一致,也可以与注解中的value一致

但是这里得注意:这里返回给前台的json对象中的key将会是直接中的值

public class User {
    private Integer id;
    @JsonProperty("name")
    private String userName;
    @JsonProperty("pass")
    private String passWord;
    private Integer age;
    private String sex;
    private String phone;
}

总结

很明显,方式一在传递参数时,如果传入的参数太长时,或许会超过某些浏览器与服务器对URL的长度限制,会导致请求失败,因此在实际应用中,对于GET请求我们一般使用form表单形式传递参数,POST/DELETE/PUT请求我们考虑使用方式二;

对于请求参数过多的,我们可以使用Java Bean来接收参数

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文