关于http:http请求的contenttype使用详解

53次阅读

共计 4146 个字符,预计需要花费 11 分钟才能阅读完成。

Content-type 类型

在 HTTP 协定音讯头中,应用 Content-Type 来示意媒体类型信息。它被用来通知服务端如何解决申请的数据,以及通知客户端(个别是浏览器)如何解析响应的数据,比方显示图片,解析 html 或仅仅展现一个文本等。

Post 申请的内容搁置在申请体中,Content-Type 定义了申请体的编码格局。数据发送进来后,还须要接收端解析才能够。接收端依附申请头中的 Content-Type 字段来获知申请体的编码格局,最初再进行解析。开发过程中次要有如下几种 content-type 类型:

  • text/xml
    该种形式次要用来提交 XML 格局的数据。
  • application/x-www-form-urlencoded

浏览器的原生 form 表单,如果不设置 enctype 属性,那么最终会以 applicatiion/x-www-form-urlencoded 形式提交数据。这种形式提交数据放在 body 外面,数据依照 key1=value1&key2=value2 的形式进行编码。

  • multipart/form-data
    这种形式也是常见的 post 提交形式,通常表单上传时应用该办法。
  • application/json
    通知服务器主体的序列化的 json 字符串。

应用场景

开发过程中次要用到“application/x-www-form-urlencoded”、“application/json”、“multipart/form-data”三种类型,上面咱们就来具体说说这三种类型的构造和在 SpringMVC 中的应用场景:

### 1. application/x-www-form-urlencoded
当 action 为 get 时候,浏览器用 x -www-form-urlencoded 的编码方式把 form 数据转换成一个字串(name1=value1&name2=value2…),而后把这个字串 append 到 url 前面,用? 宰割,加载这个新的 url。当 action 为 post 时候,浏览器把 form 数据封装到 http body 中,而后发送到 server
客户端:

  header:Content-Type=application/x-www-form-urlencoded
  Method:get 办法 - 参数须要做 URLEncode
  Post 办法 - 构建 nameValuePairList 列表放入 UrlEncodedFormEntity
List<NameValuePair> nameValuePairList = new ArrayList<~>();
        nameValuePairList.add(new BasicNameValuePair( name: "name", value: "zhangsan"));
        nameValuePairList.add(new BasicNamevaluePair( name: "birthday" value: "1990-08-25"));
        UrlEncodedFormEntity entityParam = new UrlEncodedFormEntity(namevaluePairlist,charset: "UTF-8");
        post.setEntity(entityParam);

服务端:

  申请参数不含 MultlpartFile 类型时可同时反对 GET 和 POST,具体请参考以下标准:controller 办法注解 @RequestMapping(method = {RequestMethod.POST, RequestMethod.GET})
  上传文件:只反对 POST(包含 MutipleFile 和 Base64 字符串)办法参数能够对象形成:不能加 @RequestBody 注解,否则不能接管到

    @RequestMapping(value = "/testParamForm", method = {RequestMethod.POST,RequestMethod.GET})
    @ApiOperation("Content-type:application/x-www-form-urlencoded, 同时反对 POST 和 GET,多个申请参数,无上传文件,URL 和 body 的申请参数能够失常获取,URL 的参数 encode 转码")
    @ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
    public Result testParamForm(String name, String idcard){log.info("name:{}, idcard:{}", name, idcard);

        return ResultUtil.success();}

如果是申请参数超过 3 个以上,能够封装成申请参数对象:

    @RequestMapping(value = "/testObjForm", method = {RequestMethod.POST,RequestMethod.GET})
    @ApiOperation("Content-type:application/x-www-form-urlencoded, 同时反对 POST 和 GET,封装申请参数对象,无上传文件")
    @ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
    public Result testObjForm(IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());

        return ResultUtil.success();}

### 2. application/json
客户端:

  header:Content-Type=application/json
   Mehthod:POST
  申请参数 json 字符串,格局如:"{\"name\":\" 张三 \"}",可通过构建 map 对象后再转换成 json 字符串:JSONObject.toJSONString(map)

服务端:

  Method 只反对 POST @RequestMapping(method = {RequestMethod.POST})
   办法参数能够对象形成:加 @RequestBody 注解前缀,否则不能接管到
   文件上传能够通过转换成 base64 参数 
    @RequestMapping(value = "/testJson", method = {RequestMethod.POST})
    @ApiOperation("Content-type:application/json, 只反对 POST,申请参数能够是对象,List,Map,如有上传文件,需转换成 Base64 字符串")
    @ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
    public Result testJson(@RequestBody IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());
        return ResultUtil.success();}

### 3. multipart/form-data
当申请参数有上传文件,3 个及以下申请参数,只反对 POST 申请,客户端设置申请头参数:“Content-type: multipart/form-data”:

    @RequestMapping(value = "/testMutipartParamForm", method = {RequestMethod.POST})
    @ApiOperation("Content-type:application/x-www-form-urlencoded, 只反对 POST,多个申请参数,有上传文件")
    @ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
    public Result testMutipartParamForm(String name, String idcard, MultipartFile file){log.info("name:{}, idcard:{}, file: {}", name, idcard, file);

        return ResultUtil.success();}

当申请参数有上传文件,3 个以上申请参数,封装成申请对象,不能加 @RequestBody 注解,只反对 POST 申请,客户端设置申请头参数:“Content-type: multipart/form-data”

    @RequestMapping(value = "/testMutipartObjForm", method = {RequestMethod.POST})
    @ApiOperation("Content-type:application/x-www-form-urlencoded, 只反对 POST,封装申请参数对象,有上传文件")
    @ApiResponses(value={@ApiResponse(code = 200, message = "申请胜利")})
    public Result testMutipartObjForm(IdcardRequestDto idcardRequestDto){log.info("name:{}, idcard:{}, file: {}", idcardRequestDto.getName(), idcardRequestDto.getIdcard(), idcardRequestDto.getFile());

        return ResultUtil.success();}

本案例来自于昂焱数据,更多精彩请拜访 https://www.ayshuju.com/

正文完
 0