在HTTP GET请求中,参数作为查询字符串发送:
http://example.com/page?parameter=value&also=another
在HTTP POST请求中,参数不会与URI一起发送。
价值观在哪里?在请求标头中?在请求主体中?它看起来像什么?
在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的网络部分查看有关如何向服务器发出请求的基本信息。
并且您可以始终在请求头中添加更多值,如缓存控制、源、接受。