JS之表單提交時編碼類型enctype詳解

来源:http://www.cnblogs.com/moqiutao/archive/2017/11/04/7782270.html
-Advertisement-
Play Games

簡介 form的enctype屬性為編碼方式,常用有兩種:application/x-www-form-urlencoded和multipart/form-data,預設為application/x-www-form-urlencoded。 當action為get時候,瀏覽器用x-www-form- ...


簡介

form的enctype屬性為編碼方式,常用有兩種:application/x-www-form-urlencodedmultipart/form-data,預設為application/x-www-form-urlencoded

當action為get時候,瀏覽器用x-www-form-urlencoded的編碼方式把form數據轉換成一個字串(name1=value1&name2=value2...),然後把這個字串append到url後面,用?分割,載入這個新的url。

當action為post時候,瀏覽器把form數據封裝到http body中,然後發送到server。如果沒有type=file的控制項,用預設的application/x-www-form-urlencoded就可以了。 但是如果有type=file的話,就要用到multipart/form-data了。瀏覽器會把整個表單以控制項為單位分割,併為每個部分加上Content-Disposition(form-data或者file),Content-Type(預設為text/plain),name(控制項name)等信息,並加上分割符(boundary)。

根據查找的資料得到如下總結:

  • application/x-www-form-urlencoded: 窗體數據被編碼為名稱/值對。這是標準的編碼格式。
  • multipart/form-data: 窗體數據被編碼為一條消息,頁上的每個控制項對應消息中的一個部分
  • text/plain: 窗體數據以純文本形式進行編碼,其中不含任何控制項或格式字元。

是什麼決定了表單的編碼?

熟悉表單元素<form>的小伙伴,對其中的屬性enctype一定不會陌生,就是它規定了對錶單提交給伺服器時表單數據編碼的內容類型(Content Type)。

表單編碼類型

知道了表單編碼由enctype決定的,那麼它究竟有多少可選的取值呢?是不是所有的MIME類型它都能用呢?
實際上,根據HTML5 規範中所敘述的,enctype具有以下三種選項,其中最後一項text/plain是相比4.01新增的。

  • application/x-www-form-urlencoded
  • multipart/form-data
  • text/plain

application/x-www-form-urlencoded

這是預設的編碼類型,使用該類型時,會將表單數據中非字母數字的字元轉換成轉義字元,如"%HH",然後組合成這種形式key1=value1&key2=value2;所以後端在取數據後,要進行解碼

註意:若表單中有文件,則只留文件名。

multipart/form-data

該類型用於高效傳輸文件、非ASCII數據和二進位數據,將表單數據逐項地分成不同的部分,用指定的分割符分割每一部分。每一部分都擁有Content-Disposition頭部,指定了該表單項的鍵名和一些其他信息;並且每一部分都有可選的Content-Type,不特殊指定就為text/plain。下麵給出一個採用multipart/form-data編碼類型的例子:

Request Headers:

Accept:application/json, text/plain, */*
Accept-Encoding:gzip, deflate
Accept-Language:zh-CN,zh;q=0.8
Connection:keep-alive
Content-Length:13125
Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryaqWXpQYCfMbAHgPh
Cookie:shiro.sesssion=1a6d4f4d-ab5f-4a1b-a5cd-fc71cf9633cb
Host:192.168.199.223
Origin:http://192.168.199.223
Referer:http://192.168.199.223/
User-Agent:Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.106 Safari/537.36

Request Payload:

------WebKitFormBoundaryaqWXpQYCfMbAHgPh
Content-Disposition: form-data; name="fileEnterprise"; filename="a.jpg"
Content-Type: image/jpeg


------WebKitFormBoundaryaqWXpQYCfMbAHgPh
Content-Disposition: form-data; name="enterpriseName"

有限責任公司
------WebKitFormBoundaryaqWXpQYCfMbAHgPh
Content-Disposition: form-data; name="unifiedSocialCreditCode"

91530700781667237G
------WebKitFormBoundaryaqWXpQYCfMbAHgPh--

註意:

  • 一般來說,methodenctype是兩個不同的互不影響的屬性,但在傳文件時,method必須要指定為POST,否則文件只剩下filename了;

  • 當沒有傳文件時,enctype會改回預設的application/x-www-form-urlencoded

text/plain

按照鍵值對排列表單數據key1=value1\r\nkey2=value2,不進行轉義。

註意:若表單中有文件,則只留文件名。

application/json及其他MIME類型

另外,還需要說明表單數據編碼類型application/json,已經被W3C遺棄(詳見HTML JSON Form Submission),建議不要在<form enctype="...">中使用了,即使用瞭如果瀏覽器不支持,也會替換成application/x-www-form-urlencoded
同理,其餘的MIME類型,也不支持,均會替換成預設編碼application/x-www-form-urlencoded

註:1.MIME (Multipurpose Internet Mail Extensions) 是描述消息內容類型的網際網路標準。

2.MIME 消息能包含文本、圖像、音頻、視頻以及其他應用程式專用的數據。

想要瞭解詳細的Mime 類型列表,請參考《W3school:MIME 參考手冊》

總結

所以,enctype可以認為就是表單數據的content type(MIME type),只不過其取值不能用除了上面提到的三個,否則會轉換成預設的編碼。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 使用跨平臺工具開發庫 本文介紹如何使用跨平臺 CLI 工具編寫 .NET 的庫。 CLI 提供可跨任何支持的 OS 工作的高效低級別體驗。 仍可使用 Visual Studio 生成庫,如果你首選這種體驗,請 "參閱 Visual Studio 指南" 。 先決條件 需要在電腦上安裝 ".NET ...
  • 一個項目可以按照功能劃分區域,例如前臺和後臺 右擊MVC項目->添加區域 生成一個Area文件夾,優先載入分區項目的路由 ...
  • 圖片以二進位存儲於資料庫表中。在顯示RDLC報表時,把圖片呈現出來。好吧。把存儲過程寫好: CREATE PROCEDURE [dbo].[usp_File_Select] AS SELECT [Afd_nbr],[Picture],[PictureType],[FileExtension] FRO ...
  • 描述 本篇文章簡要推薦一些常用技術博客網站 1 內容區 1 內容區 2 版權區 2 版權區 感謝您的閱讀,若有不足之處,歡迎指教,共同學習、共同進步。 博主網址:http://www.cnblogs.com/wangjiming/。 極少部分文章利用讀書、參考、引用、抄襲、複製和粘貼等多種方式整合而 ...
  • 經常遇到C#調用webservice的情況,通常來說如果webservice是用vs+c#來開發的,問題一般來說不大,直接web引用,然後調用就OK了。流程如下: 下麵就是進行調用,就這麼簡單。 但如果webservice是用JAVA或者其它語言或者其它工具生成的話,使用vs+c#來調用就經常遇到問 ...
  • 要在select標簽上面加上autocomplete="off"關閉自動完成,不然瀏覽器每次刷新後將自動選擇上一次關閉時的option,這樣預設屬性selected="selected"就會失效啦 要記住每次遇到select標簽時就最好要加上autocomplete="off"這一項 ...
  • 瞭解瞭解 ECharts,縮寫來自Enterprise Charts,商業級數據圖表,一個純Javascript的圖表庫,可以流暢的運行在PC和移動設備上,相容當前絕大部分瀏覽器(IE6/7/8/9/10/11,chrome,firefox,Safari等),底層依賴輕量級的Canvas類庫ZRen ...
  • 瞧這首頁報錯報的 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...