一、原理區別
一般我們在瀏覽器輸入乙個**訪問**都是get請求;再form表單中,可以通過設定method指定提交方式為get或者post提交方式,預設為get提交方式。
http定義了與伺服器互動的不同方法,其中最基本的四種:get,post,put,delete,head,其中get和head被稱為安全方法,因為使用get和head的http請求不會產生什麼動作。不會產生動作意味著get和head的http請求不會在伺服器上產生任何結果。但是安全方法並不是什麼動作都不產生,這裡的安全方法僅僅指不會修改資訊。
二、表現形式區別
搞清楚了兩者的原理區別後,我們來看一下在實際應用中的區別。
首先,我們先看一下http請求的格式:
[plain]
view plain
copy
在http請求中,奇異行必須是乙個請求行,包括請求方法,請求url,報文所用http版本資訊。緊接著是乙個herders小節,可以有零個或乙個首部,用來說明伺服器要使用的附加資訊。在首部之後就是乙個空行,最後就是報文實體的主體部分,包含乙個由任意資料組成的資料塊。但是並不是所有的報文都包含實體的主體部分。
get請求例項:
[plain]
view plain
copy
get
host: weibo.com
post請求例項:
接下來看看兩種請求方式的區別:
1、get請求,請求的資料會附加在url之後,以?分割url和傳輸資料,多個引數用&連線。url的編碼格式採用的是ascii編碼,而不是uniclde,即是說所有的非ascii字元都要編碼之後再傳輸。
post請求:post請求會把請求的資料放置在http請求包的包體中。上面的item=bandsaw就是實際的傳輸資料。
因此,get請求的資料會暴露在位址列中,而post請求則不會。
2、傳輸資料的大小
在http規範中,沒有對url的長度和傳輸的資料大小進行限制。但是在實際開發過程中,對於get,特定的瀏覽器和伺服器對url的長度有限制。因此,在使用get請求時,傳輸資料會受到url長度的限制。
對於post,由於不是url傳值,理論上是不會受限制的,但是實際上各個伺服器會規定對post提交資料大小進行限制,apache、iis都有各自的配置。
3、安全性
post的安全性比get的高。這裡的安全是指真正的安全,而不同於上面get提到的安全方法中的安全,上面提到的安全僅僅是不修改伺服器的資料。比如,在進行登入操作,通過get請求,使用者名稱和密碼都會暴露再url上,因為登入頁面有可能被瀏覽器快取以及其他人檢視瀏覽器的歷史記錄的原因,此時的使用者名稱和密碼就很容易被他人拿到了。除此之外,get請求提交的資料還可能會造成cross-site request frogery攻擊
4、http中的get,post,soap協議都是在http上執行的
三、http響應
http響應報文的格式
[plain]
view plain
copy
status,狀態碼描述了請求過程中發生的情況
reson-phrase 是數字狀態碼的可讀版本
常見的狀態碼以及含義如下:
200 ok 伺服器成功處理請求
301/302 moved permanently(重定向)請求的url已移走。響應報文中應該包含乙個location url,說明資源現在所處的位置
304 not modified(未修改) 客戶的快取資源是最新的,要客戶端使用快取內容
404 not found 未找到資源
501 internal server error 伺服器遇到錯誤,使其無法對請求提供服務
http響應示例
Get與Post的區別
1.href與action的區別 href只能get引數,action能get引數又能post引數 href一般用於單個連線,可以帶引數 url重寫 是採用get方式請求的,在位址列中可以看到所有的引數 action一樣用於表單的提交 如 註冊 等,他可以提交大量和比較複雜的引數,可通過post和g...
Get 與Post 的區別
get 與post 的區別 表單提交中get和post方式的區別有5點 1.get是從伺服器上獲取資料,post是向伺服器傳送資料。2.get是把引數資料佇列加到提交表單的action屬性所指的url中,值和表單內各個字段一一對應,在url中可以看到。post是通過http post機制,將表單內各...
get 與 post 的區別
先簡單的介紹一下 get與 post lget 是以實體的方式得到由請求 uri所指定資源的資訊,如果請求 uri只是乙個資料產生過程,那麼最終要在響應實體中返回的是處理過程的結果所指向的資源,而不是處理過程的描述。l post 用來向目的伺服器發出請求,要求它接受被附在請求後的實體,並把它當作請求...