zoukankan      html  css  js  c++  java
  • 常用HTTP contentType与后端处理方式

    常用HTTP contentType与后端处理方式

    1、Content-Type:application/x-www-form-urlencoded; charset=UTF-8


    前端export.json的请求

    后端export.json的处理方式

    对应的后端的处理方式,如果是单个参数去获取,那就用@RequestParam,如果是对应Java Bean,那就不需要任何注解

    2、Content-Type:application/json;charset=UTF-8


    前端list.json请求

    对应的后端处理方式,设置@RequestBody


    后端list的处理

    3、Content-Type:multipart/form-data;

    前端上传

    后端处理

    2018-1-29下班总结:

    用get方式发送参数,拼接在url后:
    image.png

    后端处理:


    HttpServletRequest对象
    从request中可以获取,用@Requestparam也可以获取
    如果是Post请求:

    1、前端传递的方式为:Body+application/x-www-form-urlencoded:

    image.png
    后端post+@RequestBody的方式来做获取,@RequestBody注解的字段获取的为key=value格式的数据,user对象也绑定了属性值,所以urlencoded的方式不需要后端特殊处理,springMVC会进行绑定

    2、如果前端改成以json字符串的形式传递参数:


    后端接收到json字符串,用阿里fastjson解析:


    后端接收的值

    3、接着上一步的后端代码,如果前端改成form-data 的方式传递,则报错:


    image.png

    将后端的代码改一下:
    加了@RequestParam、不加注解的字段、不加注解的User对象都绑定了参数值

    2、2如果前端是body+x-www-form-urlencoded方式传参,后端在解析字符串时报错:


    接收到的字符串为 json: id=tery007

    到这里,我们小小总结一下:
    如果是POST+form-data的方式:
    不需要做任何处理,直接用对象接收即可(不管有多少个对象):


    image.png

    如果是POST+x-www.form-urlencoded的方式,可以加@RequestParam注解来获取(如果不传,则报错:

    image.png
    ),也可以不加@RequestParam来获取,获取不到值的时候不报错。

    如果是POSt+json格式传递(浏览器为Request Payload,postman为raw格式)的方式:

    image.png

    后端需要用@RequestBody注解标识字段,@RequestBody的作用是接收Http请求中参数,调用HttpMessageConverter接口转化为json或xml数据并绑定到对象上。同理,@ResponseBody也是调用HttpMessageConverter接口将数据转换成json或xml格式的数据,返回给前端。


    默认赋值给加了@RequestBody的字段,接收到的是一个json数据

    最终的结论:
    json格式的数据用@RequestBody注解让HttpMessageConverter转换成json数据绑定到对象上;
    urlencoded或者form-data一般都用@RequestParam注解来标注(算是个规范吧,不加也可以),当是自己封装的实体对象时,什么都不用加。

  • 相关阅读:
    android:background背景图片被拉伸问题
    面试积累(String和StringBuffer, StringBuilder的理解)
    面试积累(冒泡排序和选择排序)
    面试积累(java的内存分析)
    面试积累(java配置环境变量)
    异常积累(SQLException)
    【linux】fdisk磁盘分区
    【走马观花】十一月十八日通州雨
    【linux】CentOS查看硬件信息
    【linux】go安装及配置
  • 原文地址:https://www.cnblogs.com/changbaishan/p/9593438.html
Copyright © 2011-2022 走看看