在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一起发送。
价值观在哪里?在请求标头中?在请求主体中?它看起来像什么?
当前回答
有些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(换行符)包装。
其他回答
值以内容类型指定的格式在请求正文中发送。
通常,内容类型是application/x-wwww-form-urlencoded,因此请求主体使用与查询字符串相同的格式:
parameter=value&also=another
当您在表单中使用文件上载时,您将改用multipart/form数据编码,它具有不同的格式。它更复杂,但你通常不需要关心它看起来是什么样子,所以我不举一个例子,但知道它的存在会很好。
首先,让我们区分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的网络部分查看有关如何向服务器发出请求的基本信息。
并且您可以始终在请求头中添加更多值,如缓存控制、源、接受。
不能直接在浏览器URL栏上键入。
例如,您可以看到POST数据是如何通过Live HTTP Headers在Internet上发送的。结果会是这样的
http://127.0.0.1/pass.php
POST /pass.php HTTP/1.1
Host: 127.0.0.1
User-Agent: Mozilla/5.0 (Windows NT 6.1; WOW64; rv:18.0) Gecko/20100101 Firefox/18.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate
DNT: 1
Referer: http://127.0.0.1/pass.php
Cookie: passx=87e8af376bc9d9bfec2c7c0193e6af70; PHPSESSID=l9hk7mfh0ppqecg8gialak6gt5
Connection: keep-alive
Content-Type: application/x-www-form-urlencoded
Content-Length: 30
username=zurfyx&pass=password
上面写着
Content-Length: 30
username=zurfyx&pass=password
将是后值。
在万维网上的CGI编程中,作者说:
使用POST方法,服务器将数据作为输入流发送到程序。。。。。因为服务器将信息传递给该程序作为输入流,它将环境变量CONTENT_LENGTH设置为以字节(或字符)为单位的数据大小。我们可以使用这可以从标准输入中准确读取那么多数据。
有些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(换行符)包装。