国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

都9102年了,還問(wèn)GET和POST的區(qū)別

h9911 / 2595人閱讀

摘要:前言最近看了一些同學(xué)的面經(jīng),發(fā)現(xiàn)無(wú)論什么技術(shù)崗位,還是會(huì)問(wèn)到和的區(qū)別,而搜索出來(lái)的答案并不能讓我們裝得一手好逼,那就讓我們從報(bào)文的角度來(lái)擼一波,從而搞明白他們的區(qū)別。所以,和分開(kāi)發(fā)送是部分瀏覽器或框架的請(qǐng)求方法,不屬于必然行為。

1 前言

最近看了一些同學(xué)的面經(jīng),發(fā)現(xiàn)無(wú)論什么技術(shù)崗位,還是會(huì)問(wèn)到 get 和 post 的區(qū)別,而搜索出來(lái)的答案并不能讓我們裝得一手好逼,那就讓我們從 HTTP 報(bào)文的角度來(lái)擼一波,從而搞明白他們的區(qū)別。

2 標(biāo)準(zhǔn)答案

在開(kāi)擼之前嗎,讓我們先看一下標(biāo)準(zhǔn)答案長(zhǎng)什么樣子 w3school: GET 對(duì)比 POST。標(biāo)準(zhǔn)答案很美好,但是在面試的時(shí)候把下面的表格甩面試官一臉,估計(jì)會(huì)裝逼不成反被*。

分類(lèi) GET POST
后退按鈕/刷新 無(wú)害 數(shù)據(jù)會(huì)被重新提交(瀏覽器應(yīng)該告知用戶(hù)數(shù)據(jù)會(huì)被重新提交)。
書(shū)簽 可收藏為書(shū)簽 不可收藏為書(shū)簽
緩存 能被緩存 不能緩存
編碼類(lèi)型 application/x-www-form-urlencoded application/x-www-form-urlencoded 或 multipart/form-data。為二進(jìn)制數(shù)據(jù)使用多重編碼。
歷史 參數(shù)保留在瀏覽器歷史中。 參數(shù)不會(huì)保存在瀏覽器歷史中。
對(duì)數(shù)據(jù)長(zhǎng)度的限制 是的。當(dāng)發(fā)送數(shù)據(jù)時(shí),GET 方法向 URL 添加數(shù)據(jù);URL 的長(zhǎng)度是受限制的(URL 的最大長(zhǎng)度是 2048 個(gè)字符)。 無(wú)限制。
對(duì)數(shù)據(jù)類(lèi)型的限制 只允許 ASCII 字符。 沒(méi)有限制。也允許二進(jìn)制數(shù)據(jù)。
安全性 與 POST 相比,GET 的安全性較差,因?yàn)樗l(fā)送的數(shù)據(jù)是 URL 的一部分。在發(fā)送密碼或其他敏感信息時(shí)絕不要使用 GET ! POST 比 GET 更安全,因?yàn)閰?shù)不會(huì)被保存在瀏覽器歷史或 web 服務(wù)器日志中。
可見(jiàn)性 數(shù)據(jù)在 URL 中對(duì)所有人都是可見(jiàn)的。 數(shù)據(jù)不會(huì)顯示在 URL 中。

注意,并不是說(shuō)標(biāo)準(zhǔn)答案有誤,上述區(qū)別在大部分瀏覽器上是存在的,因?yàn)檫@些瀏覽器實(shí)現(xiàn)了 HTTP 標(biāo)準(zhǔn)。

所以從標(biāo)準(zhǔn)上來(lái)看,GET 和 POST 的區(qū)別如下:

GET 用于獲取信息,是無(wú)副作用的,是冪等的,且可緩存

POST 用于修改服務(wù)器上的數(shù)據(jù),有副作用,非冪等,不可緩存

但是,既然本文從報(bào)文角度來(lái)說(shuō),那就先不討論 RFC 上的區(qū)別,單純從數(shù)據(jù)角度談?wù)劇?/p> 3 GET 和 POST 報(bào)文上的區(qū)別

先下結(jié)論,GET 和 POST 方法沒(méi)有實(shí)質(zhì)區(qū)別,只是報(bào)文格式不同。

GET 和 POST 只是 HTTP 協(xié)議中兩種請(qǐng)求方式,而 HTTP 協(xié)議是基于 TCP/IP 的應(yīng)用層協(xié)議,無(wú)論 GET 還是 POST,用的都是同一個(gè)傳輸層協(xié)議,所以在傳輸上,沒(méi)有區(qū)別。

報(bào)文格式上,不帶參數(shù)時(shí),最大區(qū)別就是第一行方法名不同

POST方法請(qǐng)求報(bào)文第一行是這樣的 POST /uri HTTP/1.1

GET方法請(qǐng)求報(bào)文第一行是這樣的 GET /uri HTTP/1.1

是的,不帶參數(shù)時(shí)他們的區(qū)別就僅僅是報(bào)文的前幾個(gè)字符不同而已

帶參數(shù)時(shí)報(bào)文的區(qū)別呢? 在約定中,GET 方法的參數(shù)應(yīng)該放在 url 中,POST 方法參數(shù)應(yīng)該放在 body 中

舉個(gè)例子,如果參數(shù)是 name=qiming.c, age=22。

GET 方法簡(jiǎn)約版報(bào)文是這樣的

GET /index.php?name=qiming.c&age=22 HTTP/1.1
Host: localhost

POST 方法簡(jiǎn)約版報(bào)文是這樣的

POST /index.php HTTP/1.1
Host: localhost
Content-Type: application/x-www-form-urlencoded

name=qiming.c&age=22

現(xiàn)在我們知道了兩種方法本質(zhì)上是 TCP 連接,沒(méi)有差別,也就是說(shuō),如果我不按規(guī)范來(lái)也是可以的。我們可以在 URL 上寫(xiě)參數(shù),然后方法使用 POST;也可以在 Body 寫(xiě)參數(shù),然后方法使用 GET。當(dāng)然,這需要服務(wù)端支持。

4. 常見(jiàn)問(wèn)題 GET 方法參數(shù)寫(xiě)法是固定的嗎?

在約定中,我們的參數(shù)是寫(xiě)在 ? 后面,用 & 分割。

我們知道,解析報(bào)文的過(guò)程是通過(guò)獲取 TCP 數(shù)據(jù),用正則等工具從數(shù)據(jù)中獲取 Header 和 Body,從而提取參數(shù)。

也就是說(shuō),我們可以自己約定參數(shù)的寫(xiě)法,只要服務(wù)端能夠解釋出來(lái)就行,一種比較流行的寫(xiě)法是 http://www.example.com/user/name/chengqm/age/22

POST 方法比 GET 方法安全?

按照網(wǎng)上大部分文章的解釋?zhuān)琍OST 比 GET 安全,因?yàn)閿?shù)據(jù)在地址欄上不可見(jiàn)。

然而,從傳輸?shù)慕嵌葋?lái)說(shuō),他們都是不安全的,因?yàn)?HTTP 在網(wǎng)絡(luò)上是明文傳輸?shù)模灰诰W(wǎng)絡(luò)節(jié)點(diǎn)上捉包,就能完整地獲取數(shù)據(jù)報(bào)文。

要想安全傳輸,就只有加密,也就是 HTTPS。

GET 方法的長(zhǎng)度限制是怎么回事?

在網(wǎng)上看到很多關(guān)于兩者區(qū)別的文章都有這一條,提到瀏覽器地址欄輸入的參數(shù)是有限的。

首先說(shuō)明一點(diǎn),HTTP 協(xié)議沒(méi)有 Body 和 URL 的長(zhǎng)度限制,對(duì) URL 限制的大多是瀏覽器和服務(wù)器的原因。

瀏覽器原因就不說(shuō)了,服務(wù)器是因?yàn)樘幚黹L(zhǎng) URL 要消耗比較多的資源,為了性能和安全(防止惡意構(gòu)造長(zhǎng) URL 來(lái)攻擊)考慮,會(huì)給 URL 長(zhǎng)度加限制。

POST 方法會(huì)產(chǎn)生兩個(gè)TCP數(shù)據(jù)包?

有些文章中提到,post 會(huì)將 header 和 body 分開(kāi)發(fā)送,先發(fā)送 header,服務(wù)端返回 100 狀態(tài)碼再發(fā)送 body。

HTTP 協(xié)議中沒(méi)有明確說(shuō)明 POST 會(huì)產(chǎn)生兩個(gè) TCP 數(shù)據(jù)包,而且實(shí)際測(cè)試(Chrome)發(fā)現(xiàn),header 和 body 不會(huì)分開(kāi)發(fā)送。

所以,header 和 body 分開(kāi)發(fā)送是部分瀏覽器或框架的請(qǐng)求方法,不屬于 post 必然行為。

5 talk is cheap show me the code

如果對(duì) get 和 post 報(bào)文區(qū)別有疑惑,直接起一個(gè) Socket 服務(wù)端,然后封裝簡(jiǎn)單的 HTTP 處理方法,直接觀察和處理 HTTP 報(bào)文,就能一目了然

#!/usr/bin/env python
# -*- coding: utf-8 -*-

import socket

HOST, PORT = "", 23333


def server_run():
    listen_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    listen_socket.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    listen_socket.bind((HOST, PORT))
    listen_socket.listen(1)
    print("Serving HTTP on port %s ..." % PORT)
    while True:
        # 接受連接
        client_connection, client_address = listen_socket.accept()
        handle_request(client_connection)


def handle_request(client_connection):
    # 獲取請(qǐng)求報(bào)文
    request = ""
    while True:
        recv_data = client_connection.recv(2400)
        recv_data = recv_data.decode()
        request += recv_data
        if len(recv_data) < 2400:
            break

    # 解析首行
    first_line_array = request.split("
")[0].split(" ")

    # 分離 header 和 body
    space_line_index = request.index("

")
    header = request[0: space_line_index]
    body = request[space_line_index + 4:]

    # 打印請(qǐng)求報(bào)文
    print(request)

    # 返回報(bào)文
    http_response = b"""
HTTP/1.1 200 OK




    Hello, World!


Hello, World!

""" client_connection.sendall(http_response) client_connection.close() if __name__ == "__main__": server_run()

上面代碼就是簡(jiǎn)單的打印請(qǐng)求報(bào)文然后返回 HelloWorld 的 html 頁(yè)面,我們運(yùn)行起來(lái)

[root@chengqm shell]# python httpserver.py 
Serving HTTP on port 23333 ...

然后從瀏覽器中請(qǐng)求看看

打印出來(lái)的報(bào)文

然后就可以手動(dòng)證明上述說(shuō)法,比如說(shuō)要測(cè)試 header 和 body 是否分開(kāi)傳輸,由于代碼沒(méi)有返回 100 狀態(tài)碼,如果我們 post 請(qǐng)求成功就說(shuō)明是一起傳輸?shù)?Chrome/postman)。

又比如 w3school 里面說(shuō) URL 的最大長(zhǎng)度是 2048 個(gè)字符,那我們?cè)诖a里面加上一句計(jì)算 uri 長(zhǎng)度的代碼

...
# 解析首行
first_line_array = request.split("
")[0].split(" ")
print("uri長(zhǎng)度: %s" % len(first_line_array[1]))
...

我們用 postman 直接發(fā)送超過(guò) 2048 個(gè)字符的請(qǐng)求看看

然后我們可以得出結(jié)論,url 長(zhǎng)度限制是某些瀏覽器和服務(wù)器的限制,和 HTTP 協(xié)議沒(méi)有關(guān)系。

到此,我們可以愉快地裝逼了 :)

參考:

99%的人都理解錯(cuò)了HTTP中GET與POST的區(qū)別

關(guān)于HTTP GET 和 POST

w3school: HTTP 方法:GET 對(duì)比 POST

wikipedia: 超文本傳輸協(xié)議

RFC 2068

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.specialneedsforspecialkids.com/yun/43166.html

相關(guān)文章

  • 9102年了還問(wèn)SessionCookie區(qū)別

    摘要:前言最近看了一些同學(xué)的面經(jīng),發(fā)現(xiàn)無(wú)論什么技術(shù)崗位,還是會(huì)問(wèn)到和的區(qū)別。所有學(xué)技術(shù)的同學(xué)都知道和函數(shù)怎么用,知道和的區(qū)別就是是儲(chǔ)存在服務(wù)端的,是存儲(chǔ)在瀏覽器的。的誕生是為了能讓無(wú)狀態(tài)的報(bào)文帶上一些特殊的數(shù)據(jù),讓服務(wù)端能夠辨識(shí)請(qǐng)求的身份。 1 前言 最近看了一些同學(xué)的面經(jīng),發(fā)現(xiàn)無(wú)論什么技術(shù)崗位,還是會(huì)問(wèn)到 Session 和 Cookie 的區(qū)別。 所有學(xué)技術(shù)的同學(xué)都知道 Session ...

    Bowman_han 評(píng)論0 收藏0
  • 9102年了,還不會(huì)Docker?10分鐘帶你從入門(mén)操作到實(shí)戰(zhàn)上手

    摘要:聯(lián)調(diào)測(cè)試,無(wú)需依賴(lài)他人。針對(duì)以上問(wèn)題,有兩種解決方法,一個(gè)是自己搭建私有服務(wù),另一個(gè)是用云服務(wù)的鏡像管理平臺(tái)如阿里云的容器鏡像服務(wù)。利用,先對(duì)阿里云的服務(wù)進(jìn)行登錄。推送后,就能在阿里云的倉(cāng)庫(kù)上看到這個(gè)鏡像。 Docker簡(jiǎn)述 Docker是一種OS虛擬化技術(shù),是一個(gè)開(kāi)源的應(yīng)用容器引擎。它可以讓開(kāi)發(fā)者將應(yīng)用打包到一個(gè)可移植的容器中,并且該容器可以運(yùn)行在幾乎所有l(wèi)inux系統(tǒng)中(Windo...

    sf_wangchong 評(píng)論0 收藏0
  • 9102年了,Array數(shù)組方法趕緊用起來(lái)!

    摘要:示例使用作為深度,展開(kāi)任意深度的嵌套數(shù)組會(huì)移除數(shù)組中的空項(xiàng)首先使用映射函數(shù)映射每個(gè)元素,然后將結(jié)果壓縮成一個(gè)新數(shù)組。注意對(duì)象數(shù)組不能使用方法來(lái)檢測(cè)。也就是返回值返回一個(gè)新的對(duì)象,該對(duì)象包含數(shù)組中每個(gè)索引的鍵值對(duì)。 showImg(https://segmentfault.com/img/remote/1460000019303737?w=651&h=289); 前言 寫(xiě)久了業(yè)務(wù)代碼的我...

    genedna 評(píng)論0 收藏0
  • 關(guān)于跨域問(wèn)題

    摘要:面試必考題吧,所以在這會(huì)詳細(xì)介紹以下內(nèi)容跨域產(chǎn)生的原因羅列最常用的解決方法分析各種方法原理羅列各種方法優(yōu)缺點(diǎn)什么是跨域由于瀏覽器廠商對(duì)安全性的考慮,提出了瀏覽器的同源策略做為解決方案。 面試必考題吧,所以在這會(huì)詳細(xì)介紹以下內(nèi)容 跨域產(chǎn)生的原因 羅列最常用的解決方法 分析各種方法原理 羅列各種方法優(yōu)缺點(diǎn) 什么是跨域 由于瀏覽器廠商對(duì)安全性的考慮,提出了瀏覽器的同源策略做為解決方案。它...

    ZoomQuiet 評(píng)論0 收藏0
  • 關(guān)于跨域問(wèn)題

    摘要:面試必考題吧,所以在這會(huì)詳細(xì)介紹以下內(nèi)容跨域產(chǎn)生的原因羅列最常用的解決方法分析各種方法原理羅列各種方法優(yōu)缺點(diǎn)什么是跨域由于瀏覽器廠商對(duì)安全性的考慮,提出了瀏覽器的同源策略做為解決方案。 面試必考題吧,所以在這會(huì)詳細(xì)介紹以下內(nèi)容 跨域產(chǎn)生的原因 羅列最常用的解決方法 分析各種方法原理 羅列各種方法優(yōu)缺點(diǎn) 什么是跨域 由于瀏覽器廠商對(duì)安全性的考慮,提出了瀏覽器的同源策略做為解決方案。它...

    livem 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<