博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Http Header里的Content-Type
阅读量:5153 次
发布时间:2019-06-13

本文共 2555 字,大约阅读时间需要 8 分钟。

1. 概述

Http Header里的Content-Type一般有这三种:

application/x-www-form-urlencoded:数据被编码为名称/值对。这是标准的编码格式。
multipart/form-data: 数据被编码为一条消息,页上的每个控件对应消息中的一个部分。
text/plain: 数据以纯文本形式(text/json/xml/html)进行编码,其中不含任何控件或格式字符。postman软件里标的是RAW。

form的enctype属性为编码方式,常用有两种:application/x-www-form-urlencodedmultipart/form-data,默认为application/x-www-form-urlencoded

当action为get时候,浏览器用x-www-form-urlencoded的编码方式把form数据转换成一个字串(name1=value1&name2=value2...),然后把这个字串追加到url后面,用?分割,加载这个新的url。

当action为post时候,浏览器把form数据封装到http body中,然后发送到server。 如果没有type=file的控件,用默认的application/x-www-form-urlencoded就可以了。 但是如果有type=file的话,就要用到multipart/form-data了。

当action为post且Content-Type类型是multipart/form-data,浏览器会把整个表单以控件为单位分割,并为每个部分加上Content-Disposition(form-data或者file),Content-Type(默认为text/plain),name(控件name)等信息,并加上分割符(boundary)。

2. 详细介绍

  Content-Type是返回消息中非常重要的内容,表示后面的文档属于什么MIME类型。Content-Type: [type]/[subtype]; parameter。例如最常见的就是text/html,它的意思是说返回的内容是文本类型,这个文本又是HTML格式的。原则上浏览器会根据Content-Type来决定如何显示返回的消息体内容

  enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。默认地,表单数据会编码为 "application/x-www-form-urlencoded"。就是说,在发送到服务器之前,所有字符都会进行编码(空格转换为 "+" 加号,特殊符号转换为 ASCII HEX 值)

  application/x-www-form-urlencoded   在发送前编码所有字符(默认)

  multipart/form-data                           不对字符编码。在使用包含文件上传控件的表单时,必须使用该值。

  text/plain                                          空格转换为 "+" 加号,但不对特殊字符编码。 

  HTTP请求中,

  1、get请求,参数url:http://test/ttt?name=value&name1=value1; 获取方式 Request.QueryString[key]

  2、post请求,Content-Type为application/x-www-form-urlencoded;参数在消息中也就是Form Data里面; 获取方式 Request.Form[key]

  3、post请求,如果不是上面的特定方式,由于数据格式不固定,所以只能才取最原始方式读取数据流。

       则在request payload中,通过读取流的方式来处理;Request.InputStream.Read(...);

实体(Entity)

  信息被作为请求或响应的有效负荷被传递。通俗的说就是,实体是指作为请求或者响应消息的有效载荷而传输的信息。

例如,当用户想浏览某个Web页面时,HTTP请求消息种的请求方法,响应消息中的状态码都不是有效载荷,它们都是为了实现文件下载这一最终目的而在客户于服务器之间传送的额外消息:而用户所要浏览的HTML文件及其元消息(文件大小,最近修改时间等)才是有效载荷。

有效载荷(Payload)

  通过前面的http定义可以了解到什么是payload。请求request消息或响应response消息中可能会包含真正要传递的数据,这个数据我们就称为消息的有效负荷,对应着就是request payload,response payload。知道了什么是Request Payload,那服务端是如何接收并解析出我们通过Request Payload所传递的特殊格式的数据呢(比如表单键值对参数或复杂的json对象)?

一般服务端程序会根据头字段中的Content-type的值来做特定的处理,如x-www-form-urlencoded。

下面两种情况在chrome 中 看到的方式不同:

第一种,传递的是json对象过去,但是浏览器会将他序列化以后,再传输

$.ajax({      url: _Url,      type: 'POST',      data: _Data,      async: _sync ? false : true,      contentType: "application/json",      dataType: "json"});

第二种, JSON.stringify(_Data) 将json字符串传递,所以post过去的只是一个字符串。

$.ajax({      url: _Url,      type: 'POST',      data: JSON.stringify(_Data),      async: _sync ? false : true,      contentType: "application/json",      dataType: "json"}); 

 

转载于:https://www.cnblogs.com/sunfie/p/8997323.html

你可能感兴趣的文章
Linux相关学习笔记-文件系统
查看>>
《linux 内核全然剖析》sched.c sched.h 代码分析笔记
查看>>
Android学习之——优化篇(2)
查看>>
好的开源库总结
查看>>
Winform的Bitmap调色板的一个问题
查看>>
noframes,frame,iframe,frameset 区别
查看>>
Android统计绘图工具
查看>>
Isequal IsequalToString containsString hasPrefixd的区别
查看>>
【原】关于cuteftp连不上Linux虚拟机的问题
查看>>
大众点评cat系统的搭建笔记
查看>>
[svc]sort-uniq
查看>>
[svc]mysql备份恢复及常用命令
查看>>
mysql存储引擎之MyISAM 和 InnoDB的比较
查看>>
Mybatis学习总结(五)——动态sql
查看>>
文件读、写相关的常用方法
查看>>
C#时间问题
查看>>
使用JSONP 实现跨域通信
查看>>
服务端性能测试校准v1.2
查看>>
【JavaScript】离线应用与客户端存储
查看>>
2014.12.3 ---Thema:Node.js
查看>>