常用HTTP contentType与后端处理方式
1、Content-Type:application/x-www-form-urlencoded; charset=UTF-8
data:image/s3,"s3://crabby-images/66806/66806c2da37c020bc9bf91fb5ae030798ae48469" alt=""
data:image/s3,"s3://crabby-images/c7ce2/c7ce2392d2952f50472d2092988a36d9471c0a20" alt=""
对应的后端的处理方式,如果是单个参数去获取,那就用@RequestParam,如果是对应Java Bean,那就不需要任何注解
2、Content-Type:application/json;charset=UTF-8
data:image/s3,"s3://crabby-images/c333d/c333df948fa99cfb22224a815b32cd718411be69" alt=""
对应的后端处理方式,设置@RequestBody
data:image/s3,"s3://crabby-images/6f228/6f22843426ef572cc2b4c5ad69adc4b098408353" alt=""
3、Content-Type:multipart/form-data;
data:image/s3,"s3://crabby-images/14832/148328ec1c7afa8dd7d2de6dd80e9c248192778c" alt=""
data:image/s3,"s3://crabby-images/fbc3a/fbc3ac62c217d8ff1cdc5094dafd106b13715ab9" alt=""
2018-1-29下班总结:
用get方式发送参数,拼接在url后:
data:image/s3,"s3://crabby-images/92eac/92eacd4560caa3edd201d3f8dec7a3ad85051503" alt=""
后端处理:
data:image/s3,"s3://crabby-images/02dba/02dba02f5f03d836fd7da072c5d74493e5e07b24" alt=""
data:image/s3,"s3://crabby-images/75c32/75c32f62eb4c5b0c7c20d00d9bc794f5dff16e8b" alt=""
如果是Post请求:
1、前端传递的方式为:Body+application/x-www-form-urlencoded:
data:image/s3,"s3://crabby-images/1473b/1473bf9c4bfb0956b17417451cd3f8908964ccb6" alt=""
data:image/s3,"s3://crabby-images/16b63/16b639d2c6c36142891de6a4d0ec518cce2b1a11" alt=""
2、如果前端改成以json字符串的形式传递参数:
data:image/s3,"s3://crabby-images/944c6/944c6afd0a3dad1c9bb0831c86c1110a1df70cbd" alt=""
后端接收到json字符串,用阿里fastjson解析:
data:image/s3,"s3://crabby-images/a1931/a1931d16279b994b8f87e0e48b7bf9cb7facd88b" alt=""
3、接着上一步的后端代码,如果前端改成form-data 的方式传递,则报错:
data:image/s3,"s3://crabby-images/dfcab/dfcab35364c956ef26063336d51f754ca3a4919a" alt=""
将后端的代码改一下:
data:image/s3,"s3://crabby-images/a66eb/a66eb525b320bd57c98d2967004e5de99cb4064b" alt=""
2、2如果前端是body+x-www-form-urlencoded方式传参,后端在解析字符串时报错:
data:image/s3,"s3://crabby-images/32c19/32c19af56920184ae9f9bef4ad3fa0d01366b6aa" alt=""
到这里,我们小小总结一下:
如果是POST+form-data的方式:
不需要做任何处理,直接用对象接收即可(不管有多少个对象):
data:image/s3,"s3://crabby-images/fe884/fe884366041d86a97c1b3077fdad4c168a6a4803" alt=""
如果是POST+x-www.form-urlencoded的方式,可以加@RequestParam注解来获取(如果不传,则报错:
data:image/s3,"s3://crabby-images/6fb41/6fb41be8c121c36138565e3fcc27a4eee44c3764" alt=""
如果是POSt+json格式传递(浏览器为Request Payload,postman为raw格式)的方式:
data:image/s3,"s3://crabby-images/08241/082412fec26892f362afbbadf83c205074d5c174" alt=""
后端需要用@RequestBody注解标识字段,@RequestBody的作用是接收Http请求中参数,调用HttpMessageConverter接口转化为json或xml数据并绑定到对象上。同理,@ResponseBody也是调用HttpMessageConverter接口将数据转换成json或xml格式的数据,返回给前端。
data:image/s3,"s3://crabby-images/197e9/197e9c29e7d545397246138fe6368eb106159ca8" alt=""
最终的结论:
json格式的数据用@RequestBody注解让HttpMessageConverter转换成json数据绑定到对象上;
urlencoded或者form-data一般都用@RequestParam注解来标注(算是个规范吧,不加也可以),当是自己封装的实体对象时,什么都不用加。