在HTTP GET请求中,参数作为查询字符串发送:

http://example.com/page?parameter=value&also=another

在HTTP POST请求中,参数不会与URI一起发送。

价值观在哪里?在请求标头中?在请求主体中?它看起来像什么?


当前回答

后置参数有多种方式/格式

表单数据原始数据json文件编码数据文件xml格式

它们由Header中表示为mime类型的内容类型控制。

其他回答

有些Web服务要求您分别放置请求数据和元数据。例如,远程函数可能希望签名的元数据字符串包含在URI中,而数据发布在HTTP主体中。

POST请求在语义上可能如下所示:

POST /?AuthId=YOURKEY&Action=WebServiceAction&Signature=rcLXfkPldrYm04 HTTP/1.1
Content-Type: text/tab-separated-values; charset=iso-8859-1
Content-Length: []
Host: webservices.domain.com
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Encoding: identity
User-Agent: Mozilla/3.0 (compatible; Indy Library)

name    id
John    G12N
Sarah   J87M
Bob     N33Y

这种方法使用单个内容类型(web服务器的“解析指令”)逻辑地组合了QueryString和Body Post。

请注意:HTTP/1.1左边用#32(空格)包装,右边用#10(换行符)包装。

后置参数有多种方式/格式

表单数据原始数据json文件编码数据文件xml格式

它们由Header中表示为mime类型的内容类型控制。

HTTP POST中的表单值以与查询字符串相同的格式在请求正文中发送。

有关详细信息,请参见规范。

POST请求中的默认媒体类型是application/x-wwww-form-urlencoded。这是一种对键值对进行编码的格式。密钥可以重复。每个键值对用&字符分隔,每个键值用=字符与其值分隔。

例如:

Name: John Smith
Grade: 19

编码为:

Name=John+Smith&Grade=19

这被放置在HTTP头之后的请求体中。

首先,让我们区分GET和POST

Get:这是向服务器发出的默认HTTP请求,用于从服务器检索数据和后面的查询字符串?用于检索唯一资源。

这是格式

GET /someweb.asp?data=value HTTP/1.0

这里data=value是传递的查询字符串值。

POST:它用于将数据安全地发送到服务器,因此需要任何东西,这是POST请求的格式

POST /somweb.aspHTTP/1.0
Host: localhost
Content-Type: application/x-www-form-urlencoded //you can put any format here
Content-Length: 11 //it depends
Name= somename

为什么要通过GET进行POST?

在GET中,发送到服务器的值通常附加到查询字符串中的基URL,现在有两种结果

GET请求与参数一起保存在浏览器历史记录中。因此,您的密码在浏览器历史记录中保持未加密状态。这在当时对Facebook来说是一个真正的问题。通常服务器对URI的长度有限制。如果发送的参数太多,您可能会收到414错误-URI太长

如果是后期请求,则字段中的数据将添加到正文中。计算请求参数的长度,并将其添加到内容长度的标头中,没有重要数据直接附加到URL。

您可以使用GoogleDeveloperTools的网络部分查看有关如何向服务器发出请求的基本信息。

并且您可以始终在请求头中添加更多值,如缓存控制、源、接受。