☆前台调用代码统一采用Content-Type:application/json,body :x-www-form-urlencoded(form表单默认的type) 1、.采用post方式 一、用@RequestParam分别接收String对象和List集合接参数 后台代码以下: json
1.1 参数放在url;后端
后台断点:浏览器
====》测试结果:成功app
1.2 参数放在body前后端分离
后台: Required String parameter 'liveId' is not present ====》测试结果:失败ide
****1简单得出结论 POST模式下,@RequestParam接收不到body里面的数据,但能够接收到url里的参数工具
二、用@RequestBody分别接收String对象和List集合接参数 后台代码(参数里面通常只写一个@RequestBody ,采用对象封装)post
2.1 前台将参数放在url上面测试
====》失败 错误信息大致就是参数不服 2.2 前台将参数放在body区域 --------------因为是发送json数据 后台封装到对象 因此采用raw类型ui
====>成功
****POST下 @RequestBody接收到body下json数据 接收不到url参数
二。GET模式 因为get只在url里面传参数 因此忽略body
2.1GET下的@Requestparam 后台代码
前台
====》成功
那么@Requestparam呢 先来个简单的
看来接收失败了。。。继续 将参数封装成对象接收
前台
又是失败!!!!!!!!!!!!!!
一样失败!!!
重点来了 ; 简单的测试得出结论; **不管get仍是post @Requestparam 都能接收到url里面的参数但不能接收到requestbody里面的数据 @RequestBody 只能接收body里面的数据,对url上的参数不感冒, 因此说,两个注解接收参数对get/post (能够推测到put delete 等) 没有限定,就是说接收参数和发送方式无关,和参数存在的位置有关,@RequestBody 只接受body区域的数据,而get没法发送body数据(?),, 总之@Requestparam接收url上面的参数,@RequestBody 接收body区域的json参数,json的key值必定要双引号哦(不加双引号,浏览器能够忽略这个错误,但不要依赖浏览器的包容性哦)!! 暂时到这吧! **