0%

http之请求Content-Type

概述

Content-Type,内容类型。用于定义网络文件的类型和网页的编码,告知文件接收方文件的形式,文件的编码方式。

一种常见的误解是content-type只有POST请求才需要,或者说才可以设置,这是一种误解。所有类型的请求,包括POST,GET都可以设置请求Content-Type。

实际上Content-Type是一种约定,约定的双方定义了这种数据请求,解析,返回的格式。便于正确的解析数据。

Content-Type的格式

Content-Type:type/subtype ;parameter

  • type: 主类型,任意的字符串,如text,如果是*号代表所有;
  • subtype: 子类型,任意的字符串,如html,如果是*号代表所有,用“/”与主类型隔开
  • parameter: 可选参数,如charset,boundary等。

常见Content-Type

application/x-www-form-urlencoded

HTTP会将请求参数用key1=val1&key2=val2的方式进行组织,并放到请求实体里面,注意如果是中文或特殊字符如”/“、”,”、“:” 等会自动进行URL转码。不支持文件,一般用于表单提交。

user=123&password=123

multipart/form-data

与application/x-www-form-urlencoded不同,这是一个多部分多媒体类型。首先生成了一个 boundary 用于分割不同的字段,在请求实体里每个参数以——boundary开始,然后是附加信息和参数名,然后是空行,最后是参数内容。多个参数将会有多个boundary块。如果参数是文件会有特别的文件域。最后以——boundary–为结束标识。multipart/form-data支持文件上传的格式,一般需要上传文件的表单则用该类型。

multipart/form-data
——WebKitFormBoundaryuTIWaYQlb4o0erPM
Content-Disposition: form-data; name=”sub_user_name_list”

夜枫之辰,夜枫之辰:guo
——WebKitFormBoundaryuTIWaYQlb4o0erPM
Content-Disposition: form-data; name=”id”

5de8e30c9ac778aab8be56ee
——WebKitFormBoundaryuTIWaYQlb4o0erPM–

application/json

JSON 是一种轻量级的数据格式,以“键-值”对的方式组织的数据。这个使用这个类型,需要参数本身就是json格式的数据,参数会被直接放到请求实体里,不进行任何处理。服务端/客户端会按json格式解析数据。

{“user”: “percy”, “password”: “123”}

application/xml

与application/json类似,这里用的是xml格式的数据。

request的Content-Type

  • 如果是一个restful接口(json格式),一般将Content-Type设置为application/json; charset=UTF-8;
  • 如果是文件上传,一般Content-Type设置为multipart/form-data
  • 如果普通表单提交,一般Content-Type设置为application/x-www-form-urlencoded

response的Content-Type

服务端响应(Response)的Content-Type最好也保持准确,虽然一般web开发中,前端解析响应的数据不会根据Content-Type,并且服务端一般能自动设置准确的Content-Type,但是如果乱设置某些情况下可能会有问题。

一般不需要特殊设置。在下载文件中需要设置一下Content-Type。如果是文件导出,Content-Type 设置为 multipart/form-data,并且添加一个Content-Disposition设置为attachment;fileName=文件.后缀。Content-Disposition是Content-Type的扩展,告诉浏览器弹窗下载框,而不是直接在浏览器里展示文件。因为一般浏览器对于它能够处理的文件类型,如txt,pdf 等,它都是直接打开展示,而不是弹窗下载框。

在golang中的写法

1
2
3
httpWriter.Header().Set("Content-Type", "multipart/form-data; charset=UTF-8")

httpWriter.Header().Set("Content-disposition", fmt.Sprintf("attachment; filename=%s", fileName))

参考链接

python requests流式上传:https://2.python-requests.org//zh_CN/latest/user/advanced.html#advanced

content-type详解:https://www.jianshu.com/p/de5845b4c095

http请求测试:https://ivalue2333.github.io/categories/http/