Latest web development tutorials

metodi HTTP: GET POST Confronto

I due metodi HTTP più comuni: GET e POST.


Che cosa è HTTP?

Hypertext Transfer Protocol (HTTP) è stato progettato per garantire la comunicazione tra il client e il server.

HTTP è una richiesta lavora tra client e server - protocollo di risposta.

browser web può essere il client e applicazioni di rete sul computer può essere utilizzato anche come server.

Esempio: il client (browser) a presentare una richiesta HTTP al server, il server restituisce la risposta al client. La risposta contiene informazioni sullo stato della richiesta e il contenuto può essere richiesto.


Due tipi di metodi di richiesta HTTP: GET e POST

Tra il client e il server di richiesta - risposta ai due metodi più comunemente usati sono: GET e POST.

  • GET - dati di richiesta dalla risorsa specificata.
  • POST - presentazione dei dati da elaborare per le risorse designate.

metodo GET

Si prega di notare che la stringa di query (coppie nome / valore) vengono inviati nella richiesta URL GET:

/test/demo_form.php?name1=value1&name2=value2

GET richieste su alcuni degli altri commenti:

  • GET richiesta può essere memorizzato nella cache
  • richiesta GET rimane nella cronologia del browser
  • GET richieste possono essere contrassegnate
  • GET richieste non devono essere utilizzati quando si tratta di dati sensibili
  • GET richieste hanno limiti di lunghezza
  • GET richieste devono essere usati solo per recuperare i dati

metodo POST

Si prega di notare che la stringa di query (coppie nome / valore) vengono inviati in una richiesta HTTP POST corpo del messaggio di:

POST /test/demo_form.php HTTP/1.1
Host: w3cschool.cc
name1=value1&name2=value2

POST richieste su alcuni degli altri commenti:

  • richieste POST non vengono memorizzati nella cache
  • richieste POST non vengono mantenute nella cronologia del browser
  • POST non possono essere contrassegnate
  • richieste POST per la lunghezza dei dati non richiede

Confronto GET e POST

La tabella seguente mette a confronto i due metodi HTTP: GET e POST.

  GET POST
后退按钮/刷新 无害 数据会被重新提交(浏览器应该告知用户数据会被重新提交)。
书签 可收藏为书签 不可收藏为书签
缓存 能被缓存 不能缓存
编码类型 application/x-www-form-urlencoded application/x-www-form-urlencoded or multipart/form-data。为二进制数据使用多重编码。
历史 参数保留在浏览器历史中。 参数不会保存在浏览器历史中。
对数据长度的限制 是的。当发送数据时,GET 方法向 URL 添加数据;URL 的长度是受限制的(URL 的最大长度是 2048 个字符)。 无限制。
对数据类型的限制 只允许 ASCII 字符。 没有限制。也允许二进制数据。
安全性 与 POST 相比,GET 的安全性较差,因为所发送的数据是 URL 的一部分。

在发送密码或其他敏感信息时绝不要使用 GET !
POST 比 GET 更安全,因为参数不会被保存在浏览器历史或 web 服务器日志中。
可见性 数据在 URL 中对所有人都是可见的。 数据不会显示在 URL 中。


Altri metodi di richiesta HTTP

La seguente tabella elenca alcuni degli altri metodi di richiesta HTTP:

方法 描述
HEAD 与 GET 相同,但只返回 HTTP 报头,不返回文档主体。
PUT 上传指定的 URI 表示。
DELETE 删除指定资源。
OPTIONS 返回服务器支持的 HTTP 方法。
CONNECT 把请求连接转换到透明的 TCP/IP 通道。