美文网首页
HTTP-GET与POST

HTTP-GET与POST

作者: Sbabysbreath | 来源:发表于2020-07-23 17:20 被阅读0次

    一、 作用


    • GET :获取资源
    • POST :传输实体主体

    二、参数


    • GET 和 POST 的请求都能使用额外的参数,但是 GET 的参数是以查询字符串出现在 URL 中,而 POST 的参数存储在实体主体中。不能因为 POST 参数存储在实体主体中就认为它的安全性更高,因为照样可以通过一些抓包工具(Fiddler)查看。
    • 因为** URL 只支持 ASCII 码,因此 GET 的参数中如果存在中文等字符就需要先进行编码。例如 中文 会转换为 %E4%B8%AD%E6%96%87,而空格会转换为 %20POST 参数支持标准字符集**。
    GET /test/demo_form.asp?name1=value1&name2=value2 HTTP/1.1
    
    
    POST /test/demo_form.asp HTTP/1.1
    Host: w3schools.com
    name1=value1&name2=value2
    
    

    三、安全


    • 安全的 HTTP 方法不会改变服务器状态,也就是说它只是可读的
    • GET 方法是安全的,而 POST 却不是,因为 POST 的目的是传送实体主体内容,这个内容可能是用户上传的表单数据,上传成功之后,服务器可能把这个数据存储到数据库中,因此状态也就发生了改变。
    • 安全的方法除了 GET 之外还有:HEAD、OPTIONS。
    • 不安全的方法除了 POST 之外还有 PUT、DELETE。

    四、幂等性


    • 幂等的 HTTP 方法,同样的请求被执行一次与连续执行多次的效果是一样的,服务器的状态也是一样的。换句话说就是,幂等方法不应该具有副作用(统计用途除外)。
    • 所有的安全方法也都是幂等的。
    • 在正确实现的条件下,GET,HEAD,PUT 和 DELETE 等方法都是幂等的,而 POST 方法不是。

    GET /pageX HTTP/1.1 是幂等的,连续调用多次,客户端接收到的结果都是一样的:

    GET /pageX HTTP/1.1
    GET /pageX HTTP/1.1
    GET /pageX HTTP/1.1
    GET /pageX HTTP/1.1
    
    

    POST /add_row HTTP/1.1 不是幂等的,如果调用多次,就会增加多行记录:

    POST /add_row HTTP/1.1   -> Adds a 1nd row
    POST /add_row HTTP/1.1   -> Adds a 2nd row
    POST /add_row HTTP/1.1   -> Adds a 3rd row
    
    

    DELETE /idX/delete HTTP/1.1 是幂等的,即使不同的请求接收到的状态码不一样:

    DELETE /idX/delete HTTP/1.1   -> Returns 200 if idX exists
    DELETE /idX/delete HTTP/1.1   -> Returns 404 as it just got deleted
    DELETE /idX/delete HTTP/1.1   -> Returns 404
    
    

    五、可缓存


    如果要对响应进行缓存,需要满足以下条件:

    • 请求报文的 HTTP 方法本身是可缓存的,包括 GET 和 HEAD,但是 PUT 和 DELETE 不可缓存,POST 在多数情况下不可缓存的。
    • 响应报文的状态码是可缓存的,包括:200, 203, 204, 206, 300, 301, 404, 405, 410, 414, and 501。
    • 响应报文的 Cache-Control 首部字段没有指定不进行缓存。

    六、XMLHttpRequest

    为了阐述 POST 和 GET 的另一个区别,需要先了解 XMLHttpRequest:

    XMLHttpRequest 是一个 API,它为客户端提供了在客户端和服务器之间传输数据的功能。它提供了一个通过 URL 来获取数据的简单方式,并且不会使整个页面刷新。这使得网页只更新一部分页面而不会打扰到用户。XMLHttpRequest 在 AJAX 中被大量使用。

    • 在使用 XMLHttpRequest 的 POST 方法时,浏览器会先发送 Header 再发送 Data。但并不是所有浏览器会这么做,例如火狐就不会。
    • 而 GET 方法 Header 和 Data 会一起发送。

    相关文章

      网友评论

          本文标题:HTTP-GET与POST

          本文链接:https://www.haomeiwen.com/subject/jwfhlktx.html