@RequestBody注解风析

get和post

GET可以拥有请求体,RFC 文档中从来就没有说过 GET 没有请求体.RFC 只是说GET 意味着通过 URI 来识别资源。所以GET请求体中的数据一般都是不做处理的,有些 http 的 lib 里不让甚至直接不提供 GET 方法追加请求体的操作。

POST请求拥有请求体,并且请求数据一般都是放在请求体当中的。所以在处理POST请求时,通常都是从请求体中获取数据。

1.@RequestBody

1.1用途:
  • 用于接收前端传递给后端的json字符串中的数据。(处理json格式的数据)
  • @RequestBody用来接收前端传递给后端的json字符串中的数据,GET方式的请求一般通过URL中携带key-value参数,而@RequestBody接收的是请求体中的数据(json格式的数据,只有请求体中能保存json),所以使用@RequestBody接收数据的时候必须是POST方式等方式。
  • @RequestBody与@RequestParam()可以同时使用,但@RequestBody最多只能有一个,而@RequestParam()可以多个。
1.2语法:
(@RequestBody Map map)
(@RequestBody Object object)
  • (@RequestBody Map map)先对简单,将json解析成Map形式的key-value对,直接通过map.get(“KeyName”)就能拿到值了
  • (@RequestBody Object object) 通过json字符串中的key来匹配对应实体类的属性如果匹配一致且json中的该key对应的值符合实体类的对应属性的类型要求时,会调用实体类的setter方法将值注入到该属性。

如:

public Result deleteBookById(@RequestBody HashMap<String, String> map) {
        this.bookService.deleteBookById(Long.parseLong(map.get("id")));
        return Result.createWithSuccessMessage();
    }

public Result updateBookById(@RequestBody Book book){
        Book record = this.bookService.updateBookById(book);
        return Result.createWithModel(record);
    }

注意:

  • 在(@RequestBody Object object)中,前端POST过来的数据会通过反序列数据到实体类中,并且在反序列的过程中会进行类型的转换。
  • 在json中应该用null来代表空值,如果是""(空字符串)会判断为空串,如果实体类属性是String类型的,那么接受到的就是"",如果实现类属性类型是Integer、Double等类型,那么接收到的就是null。
{
	name:"",
	age:null
}
  • (@RequestBody Object object)内部是通过传递过来的数据中的Key寻找setter方法,有则调用,无则不作任何操作(其实可以设计)。
  • 如果通过Key匹配到setter方法,但是Value无法转换为对应的实例类属性的类型时,抛出异常。

2.@RequestParam

2.1 用途:
  • @RequestParam用来处理 Content-Type 为 application/x-www-form-urlencoded 编码的内容,Content-Type默认为该属性。

  • 可以用于接收URL中的参数并捆绑到方法的参数中,也可以接受post请求体中的Content-Type 为 application/x-www-form-urlencoded的数据。(post比较常用的是json格式数据)

语法:
@RequestParam(value=”参数名”,required=true/false,defaultValue=””)
  • value:参数的key
  • required:是否为必须,请求中必须包含该参数,如果不包含就报错。
  • defaultValue:代替的默认参数值,设置后required将自动置false

如:

public ModelAndView getUserByName(@RequestParam("name")String name){
        ModelAndView mv = new ModelAndView();
        log.info(name);
        return mv;
}

//必须携带name参数
public ModelAndView getUserByName2(@RequestParam("name",required="true")String name){
        ModelAndView mv = new ModelAndView();
        log.info(name);
        return mv;
}

3.两者混合使用

  • @RequestBody与@RequestParam()可以同时使用,但@RequestBody最多只能有一个,而@RequestParam()可以多个。
public Result deleteBookById(@RequestBody HashMap<String, String> map,@RequestParam("name")String name) {
        System.out.println(map.get("id"));
        System.out.println(name);
        return Result.createWithSuccessMessage();
}
Logo

华为开发者空间,是为全球开发者打造的专属开发空间,汇聚了华为优质开发资源及工具,致力于让每一位开发者拥有一台云主机,基于华为根生态开发、创新。

更多推荐