婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > 都2019年了,還問http中GET和POST的區(qū)別

都2019年了,還問http中GET和POST的區(qū)別

熱門標(biāo)簽:地圖標(biāo)注審核工作怎么樣注冊 南召400電話辦理資費(fèi) 福建ai電銷機(jī)器人加盟公司 無錫電銷機(jī)器人銷售 招聘信息 去哪里辦卡 地圖標(biāo)注植物名稱 熱血傳奇沃瑪森林地圖標(biāo)注 鄭州中國移動(dòng)400電話申請 揭陽外呼系統(tǒng)公司

1、前言

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

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

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

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

注意,并不是說標(biāo)準(zhǔn)答案有誤,上述區(qū)別在大部分瀏覽器上是存在的,因?yàn)檫@些瀏覽器實(shí)現(xiàn)了 HTTP 標(biāo)準(zhǔn)。但是,前面列舉的只是瀏覽器實(shí)現(xiàn)上的區(qū)別,而不是 get 和 post 的本質(zhì)區(qū)別。

3、GET 和 POST 報(bào)文上的區(qū)別

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

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

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

POST方法請求報(bào)文第一行是這樣的 POST /uri HTTP/1.1 \r\n

GET方法請求報(bào)文第一行是這樣的 GET /uri HTTP/1.1 \r\n

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

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

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

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

GET /index.php?name=qiming.cage=22 HTTP/1.1
Host: localhost

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

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

name=qiming.cage=22

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

4、常見問題

GET 方法參數(shù)寫法是固定的嗎?
在約定中,我們的參數(shù)是寫在 ? 后面,用 分割。

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

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

POST 方法比 GET 方法安全?

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

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

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

GET 方法的長度限制是怎么回事?

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

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

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

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

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

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

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

5、talk is cheap show me the code

如果對 get 和 post 報(bào)文區(qū)別有疑惑,直接起一個(gè) Socket 服務(wù)端,然后封裝簡單的 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):
  # 獲取請求報(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('\r\n')[0].split(' ')

  # 分離 header 和 body
  space_line_index = request.index('\r\n\r\n')
  header = request[0: space_line_index]
  body = request[space_line_index + 4:]

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

  # 返回報(bào)文
  http_response = b"""\

HTTP/1.1 200 OK

!DOCTYPE html>
html>
head>
  title>Hello, World!/title>
/head>
body>
p style="color: green">Hello, World!/p>
/body>
/html>
"""
  client_connection.sendall(http_response)
  client_connection.close()


if __name__ == '__main__':
  server_run()

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

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

然后從瀏覽器中請求看看

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

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

又比如 w3school 里面說 URL 的最大長度是 2048 個(gè)字符,那我們在代碼里面加上一句計(jì)算 uri 長度的代碼

...
# 解析首行
first_line_array = request.split('\r\n')[0].split(' ')
print('uri長度: %s' % len(first_line_array[1]))
...

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

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

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

參考:

  1. 99%的人都理解錯(cuò)了HTTP中GET與POST的區(qū)別
  2. 關(guān)于HTTP GET 和 POST
  3. w3school: HTTP 方法:GET 對比 POST
  4. wikipedia: 超文本傳輸協(xié)議
  5. RFC 2068

這篇文章就介紹到這了,關(guān)于更多http中GET和POST的區(qū)別,請大家可以看腳本之家以前發(fā)布的文章。

您可能感興趣的文章:
  • python中g(shù)et和post有什么區(qū)別
  • Python大數(shù)據(jù)之網(wǎng)絡(luò)爬蟲的post請求、get請求區(qū)別實(shí)例分析
  • 對Django 中request.get和request.post的區(qū)別詳解
  • JSP之表單提交get和post的區(qū)別詳解及實(shí)例
  • 詳解Http協(xié)議以及post與get區(qū)別

標(biāo)簽:南昌 桂林 鹽城 黔南 宣城 文山 東莞 景德鎮(zhèn)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《都2019年了,還問http中GET和POST的區(qū)別》,本文關(guān)鍵詞  都,2019年,了,還問,http,中,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《都2019年了,還問http中GET和POST的區(qū)別》相關(guān)的同類信息!
  • 本頁收集關(guān)于都2019年了,還問http中GET和POST的區(qū)別的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    日韩精品高清不卡| 亚洲久草在线视频| 国产精品入口麻豆原神| 日韩不卡免费视频| 欧美一级黄色片| 奇米一区二区三区av| 欧美少妇bbb| 日日夜夜一区二区| 99久久久国产精品| 国产精品进线69影院| 国产乱码精品一区二区三| 久久国产麻豆精品| 色天天综合久久久久综合片| 日韩精品资源二区在线| 中文字幕一区二区视频| 亚洲最色的网站| 91精品国产aⅴ一区二区| 日韩美女视频一区二区 | 精品在线播放午夜| 色屁屁一区二区| 青草av.久久免费一区| 色综合天天综合网天天看片| 欧美激情综合五月色丁香小说| 亚洲综合一区二区三区| 不卡的av网站| 夜夜揉揉日日人人青青一国产精品| 国产精品白丝jk黑袜喷水| 久久久久久一二三区| 国产v综合v亚洲欧| 一区二区三区毛片| 日韩西西人体444www| 日本vs亚洲vs韩国一区三区二区 | 亚洲一区免费视频| 56国语精品自产拍在线观看| 五月婷婷综合网| 欧美变态凌虐bdsm| 国产91在线看| 欧美一卡2卡三卡4卡5免费| 日本不卡的三区四区五区| 91精品欧美久久久久久动漫| 在线观看一区不卡| 91久久香蕉国产日韩欧美9色| 91蜜桃免费观看视频| av一本久道久久综合久久鬼色| 国产成人av一区二区三区在线| 一区二区三区资源| 一区二区三区免费网站| 久久久国产精华| 欧美激情一区三区| 一区二区三区资源| 国产欧美视频一区二区三区| 精品在线一区二区| 欧美精品久久久久久久多人混战| 自拍av一区二区三区| 国产一区二区三区免费看| 精品奇米国产一区二区三区| 性久久久久久久久久久久| 色综合久久88色综合天天免费| 国产精品家庭影院| 国产乱妇无码大片在线观看| 2020日本不卡一区二区视频| 紧缚奴在线一区二区三区| 国产亚洲欧美中文| www.在线欧美| 国产在线播放一区三区四| 国产午夜精品在线观看| 色视频欧美一区二区三区| 亚洲欧洲国产专区| 日韩免费电影一区| 91色在线porny| 蜜桃视频免费观看一区| 久久精品夜色噜噜亚洲a∨| 欧美亚洲禁片免费| 韩国中文字幕2020精品| 亚洲伦在线观看| 欧美肥胖老妇做爰| 欧美三级蜜桃2在线观看| 国产精品一区二区三区网站| 一区二区三区四区在线免费观看 | 亚洲视频一区二区在线| 欧美一区二区三区白人| 色综合久久久久久久久| 国产成人在线视频网站| 亚洲成人免费电影| 亚洲青青青在线视频| 久久精品欧美一区二区三区不卡| 欧美午夜精品一区二区蜜桃| 91国偷自产一区二区三区成为亚洲经典 | 麻豆精品一区二区三区| 亚洲伦理在线精品| 亚洲国产一区二区视频| 久久久久久久久岛国免费| 日韩欧美成人午夜| 日韩三级中文字幕| 久久久久久久久蜜桃| 久久久精品人体av艺术| 国产拍欧美日韩视频二区| 国产偷v国产偷v亚洲高清| 91麻豆精品久久久久蜜臀| 欧美区在线观看| 中文字幕第一区| 亚洲伦在线观看| 午夜精品在线看| 99视频国产精品| 欧美高清性hdvideosex| 在线观看av一区二区| 国产日本欧美一区二区| 亚洲aaa精品| 亚洲欧美电影一区二区| 久久九九99视频| 一区二区在线免费观看| 日韩和欧美一区二区三区| 亚洲一区二区视频在线观看| 日本电影亚洲天堂一区| 欧美成人a∨高清免费观看| 亚洲男人的天堂av| 国内一区二区在线| 亚洲日本一区二区| 男人操女人的视频在线观看欧美| 国产综合色视频| 欧美精品一卡两卡| 亚洲高清视频在线| 99久久夜色精品国产网站| 欧美国产激情二区三区| **欧美大码日韩| 国产成人高清在线| 久久一留热品黄| 国精品**一区二区三区在线蜜桃| 欧美日韩久久不卡| 亚洲影视在线观看| 欧美日韩一区久久| 一区二区不卡在线播放 | 久久综合久久综合久久| 奇米影视一区二区三区| 欧美一区二区网站| 蜜桃免费网站一区二区三区| 日韩亚洲欧美成人一区| 另类小说欧美激情| 国产三级精品三级| 色av成人天堂桃色av| 亚洲超碰精品一区二区| 欧美人狂配大交3d怪物一区| 久久疯狂做爰流白浆xx| 国产清纯美女被跳蛋高潮一区二区久久w| 久久精品72免费观看| 久久婷婷久久一区二区三区| 波多野结衣一区二区三区| 亚洲国产美女搞黄色| 国产午夜亚洲精品午夜鲁丝片| 91老师国产黑色丝袜在线| 91日韩一区二区三区| 亚洲靠逼com| 亚洲女爱视频在线| 亚洲精品成人精品456| 国产一区二区在线免费观看| 91精品免费在线观看| 丁香天五香天堂综合| 亚洲激情图片小说视频| 26uuu国产日韩综合| 欧美电影影音先锋| 欧美性做爰猛烈叫床潮| 国产成人在线看| 韩国午夜理伦三级不卡影院| 亚洲一区二区三区在线播放| 欧美激情中文字幕| 国产丝袜美腿一区二区三区| 欧美电影免费观看高清完整版| 欧美日韩在线三级| 欧美日韩免费观看一区三区| 91成人看片片| 欧日韩精品视频| 日本福利一区二区| 欧美丰满美乳xxx高潮www| 欧美美女直播网站| 67194成人在线观看| 欧美精品一区二区三区蜜桃视频 | 欧美日韩一区二区在线观看| a在线欧美一区| 91在线精品秘密一区二区| 成人国产精品免费观看视频| 99久久久国产精品免费蜜臀| 91福利视频久久久久| 欧美日本在线观看| 精品福利av导航| 最新国产成人在线观看| 一区二区三区四区视频精品免费 | 蜜臀91精品一区二区三区 | 欧美日韩不卡视频| 精品国一区二区三区| 欧美经典三级视频一区二区三区| 国产精品理伦片| 成人国产精品免费观看视频| 91久久精品日日躁夜夜躁欧美| 另类小说综合欧美亚洲| 91亚洲国产成人精品一区二三| 欧美私人免费视频| 日本一区二区三区在线观看| 石原莉奈一区二区三区在线观看| 粉嫩在线一区二区三区视频| 欧美午夜视频网站|