关于前端:细数contentType参数在请求头中的可选值以及作用

70次阅读

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

细数 contentType 参数在申请头中的可选值以及作用

之前有文章中说到 http request-header 中局部参数的介绍,讲的比拟粗略,也没有说到 content-type,明天就专门来看看这个不起眼,然而作用很大的属性。

要晓得什么是 Content-Type,首先要理解什么是 Internet Media Type。Internet Media Type 即互联网媒体类型,也叫做 MIME 类型,应用两局部标识符来确定一个类型。在 HTTP 协定音讯头中,应用 Content-Type 来示意具体申请中的媒体类型信息,意思就是说,Content-Type 是 Internet Media Type 在 HTTP 协定中的别称。

Content-Type 的格局

type/subtype(;parameter)? type

下面是 Content-Type 的格局,能够拆解为三个局部,别离是主类型(type)、子类型(subtype)和参数(parameter)。

主类型(type)

主类型能够是任意的字符串,比方 text。如果是 * 号则代表所有类型。

子类型(subtype)

子类型能够是任意的字符串,比方 html。如果是 * 号则代表所有类型。

参数(parameter)

参数是可选的,能够在 Content-Type 中退出一些非凡的参数,比方 Accept 申请头的参数,常见的有用于设置字符编码的 charset 参数。

Content-Type: text/html;charset:utf-8;

前端传递给后端的数据类型,个别就是文件还有纯数据。

文件的话,咱们应用表单上传。数据的话,咱们是用 json 格局上传。这当下最正经的解决形式。当然还有浏览器的原生表单,应用 XML 作为编码格局的数据传输。

依照上一段话介绍的程序,咱们介绍一下对应的参数

1、multipart/form-data

它会将表单的数据处理为一条音讯,以标签为单元,用分隔符离开。既能够上传键值对也能够上传文件。当然,因为能够 append 多个键值,所以也能够上传多个文件

2、application/json

传送的是 json 格局的数据,用起来相当不便

3、application/x-www-form-urlencoded

浏览器的原生 form 表单。提交的数据依照 key1=val1&key2=val2 的形式进行编码,key 和 val 都进行了 URL 转码。大部分服务端语言都对这种形式有很好的反对。

4、text/xml

相比于 JSON,XML 不能更好的实用于数据交换,它蕴含了太多的包装, 而且它跟大多数编程语言的数据模型不匹配,让大多数程序员感到惊讶,XML 是面向数据的,JSON 是面向对象和构造的,后者会给程序员一种更加亲切的感觉。
小结:

选用不同的 content-type 属性值,会让浏览器将数据依照特定格局进行转换传送给后盾,同时告知给服务器该参数类型。如果选用不当,后盾的小伙伴就收不到数据啦

正文完
 0