日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當(dāng)前位置:首頁 > 科技  > 軟件

Go HTTP GET 請求可以發(fā)送 body 嗎

來源: 責(zé)編: 時間:2023-11-28 09:36:02 270觀看
導(dǎo)讀大家好,我是煎魚。前段時間遇到一個朋友,他跟我說他們在開發(fā)一個 Go 項(xiàng)目時,遇到了一個爭議點(diǎn),說來也好理解。WEB UI 端選擇 GET、POST 類型時,程序是否要區(qū)分所傳遞的值(例如:Body),還是不管是什么類型都傳。圖片一派認(rèn)為無所

大家好,我是煎魚。lJC28資訊網(wǎng)——每日最新資訊28at.com

前段時間遇到一個朋友,他跟我說他們在開發(fā)一個 Go 項(xiàng)目時,遇到了一個爭議點(diǎn),說來也好理解。WEB UI 端選擇 GET、POST 類型時,程序是否要區(qū)分所傳遞的值(例如:Body),還是不管是什么類型都傳。lJC28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片lJC28資訊網(wǎng)——每日最新資訊28at.com

一派認(rèn)為無所謂,反正都能傳。又沒限制。lJC28資訊網(wǎng)——每日最新資訊28at.com

一派認(rèn)為規(guī)范如此,不應(yīng)該傳。應(yīng)該針對 HTTP POST 類型,使用 POST 請求的 body 來傳遞參數(shù)。在 GET 請求里使用 URI 來進(jìn)行參數(shù)傳遞。lJC28資訊網(wǎng)——每日最新資訊28at.com

看著似乎都有各自的道理,僵持不下。lJC28資訊網(wǎng)——每日最新資訊28at.com

RFC7231 怎么說

要看互聯(lián)網(wǎng)協(xié)議的相關(guān)標(biāo)準(zhǔn),必然是 RFC 了。首先看看 RFC7231[1] 中的 4.3.1 小節(jié)是怎么說的。lJC28資訊網(wǎng)——每日最新資訊28at.com

如下摘抄:lJC28資訊網(wǎng)——每日最新資訊28at.com

A payload within a GET request message has no defined semantics; sending a payload body on a GET request might cause some existing implementations to reject the request.lJC28資訊網(wǎng)——每日最新資訊28at.com

大概意思:在 GET 類型的請求里使用 body 是一個沒有定義的語義。如果在 GET 請求的 body 里傳遞參數(shù)可能會被某些實(shí)現(xiàn)方拒絕該請求。lJC28資訊網(wǎng)——每日最新資訊28at.com

也就是這個混著傳的行為并不符合 RFC 規(guī)范,至少官方是不推薦不鼓勵這樣的使用方式。但并沒有禁止這個行為。lJC28資訊網(wǎng)——每日最新資訊28at.com

記住這個結(jié)論。接下來我們進(jìn)行測試。lJC28資訊網(wǎng)——每日最新資訊28at.com

程序支持程度

我們起一個 HTTP Sever 用于測試和驗(yàn)證,看看在具體的編程語言的實(shí)現(xiàn)中是否可以支持。lJC28資訊網(wǎng)——每日最新資訊28at.com

如下 Go 代碼:lJC28資訊網(wǎng)——每日最新資訊28at.com

func hello(w http.ResponseWriter, req *http.Request) { b, _ := io.ReadAll(req.Body) w.Write(b)}func main() { http.HandleFunc("/hello_world", hello) http.ListenAndServe(":7001", nil)}

在命令行執(zhí)行 CURL 進(jìn)行測試:lJC28資訊網(wǎng)——每日最新資訊28at.com

$ curl -X GET localhost:7001/hello_world -d '煎魚'煎魚

看來在 Go 里面是可以的。lJC28資訊網(wǎng)——每日最新資訊28at.com

那既然 RFC 沒有禁止,Go 的測試也正常。看來就是只是口頭上的 “不鼓勵” 和 “不推薦” 嗎?lJC28資訊網(wǎng)——每日最新資訊28at.com

那別的場景也都支持嗎?lJC28資訊網(wǎng)——每日最新資訊28at.com

實(shí)際上也不是,例如:XMLHttpRequest 規(guī)范[2] 中有明確提到:lJC28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片lJC28資訊網(wǎng)——每日最新資訊28at.com

如果請求方法為 GET 或 HEAD,body 參數(shù)會被忽略。lJC28資訊網(wǎng)——每日最新資訊28at.com

總結(jié)

在 GET 類型里傳 body 參數(shù),從 RFC7231 標(biāo)準(zhǔn)來定義。官方是不推薦、不鼓勵這么去使用的。lJC28資訊網(wǎng)——每日最新資訊28at.com

但是呢,這是一個沒有明確禁止的事。lJC28資訊網(wǎng)——每日最新資訊28at.com

而從各個 HTTP 實(shí)現(xiàn)的客戶端來看,一開始還是有不少不支持的。但掰扯了好多年后,大多數(shù)都支持了。(畢竟用戶的訴求也是很重要的)lJC28資訊網(wǎng)——每日最新資訊28at.com

甚至印象最深的,ES 直接就在 GET 請求里傳了 body:lJC28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片lJC28資訊網(wǎng)——每日最新資訊28at.com

對應(yīng)的 CURL:lJC28資訊網(wǎng)——每日最新資訊28at.com

curl -X GET "localhost:9200/my-index-000001/_search?from=40&size=20&pretty" -H 'Content-Type: application/json' -d'{  "query": {    "term": {      "user.id": "kimchy"    }  }}'

但也有不支持的,例如在 Chrome 瀏覽器下測試 XMLHttpRequest、Fetch 對此都會忽略或出現(xiàn)報錯。lJC28資訊網(wǎng)——每日最新資訊28at.com

圖片圖片lJC28資訊網(wǎng)——每日最新資訊28at.com

Fetch GET bodylJC28資訊網(wǎng)——每日最新資訊28at.com

結(jié)論上來講,GET 請求能不能傳 body,這是一個 RFC 規(guī)范不鼓勵。但是實(shí)現(xiàn)方大部分都支持的一個情況。lJC28資訊網(wǎng)——每日最新資訊28at.com

企業(yè)和團(tuán)隊(duì)內(nèi)部的話,建議達(dá)成研發(fā)規(guī)范的共識即可。不過我個人而言,都會區(qū)分開。lJC28資訊網(wǎng)——每日最新資訊28at.com

參考資料

[1]RFC7231: https://datatracker.ietf.org/doc/pdf/rfc7231.pdflJC28資訊網(wǎng)——每日最新資訊28at.com

[2]XMLHttpRequest 規(guī)范: https://xhr.spec.whatwg.orglJC28資訊網(wǎng)——每日最新資訊28at.com

本文鏈接:http://www.www897cc.com/showinfo-26-34642-0.htmlGo HTTP GET 請求可以發(fā)送 body 嗎

聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: Python VTK 初探數(shù)據(jù)源

下一篇: 用Python Requests庫輕松實(shí)現(xiàn)網(wǎng)絡(luò)爬蟲,學(xué)會抓取數(shù)據(jù)!

標(biāo)簽:
  • 熱門焦點(diǎn)
Top 主站蜘蛛池模板: 饶河县| 沁水县| 武强县| 余干县| 化德县| 榆社县| 弥渡县| 德清县| 万全县| 卢氏县| 石柱| 抚远县| 共和县| 东港市| 大渡口区| 壶关县| 龙胜| 乌拉特后旗| 鄂伦春自治旗| 滨州市| 南阳市| 克山县| 潼关县| 平凉市| 韩城市| 陆丰市| 商河县| 南昌县| 大石桥市| 西城区| 台江县| 永川市| 颍上县| 定边县| 定南县| 奉节县| 襄垣县| 虞城县| 宜良县| 青铜峡市| 丽水市|