1. 程式人生 > >HTTP中application/x-www-form-urlencoded字元說明

HTTP中application/x-www-form-urlencoded字元說明

在學習ajax的時候,如果用post請求,需要設定如下程式碼。

ajax.setRequestHeader("content-type","application/x-www-form-urlencoded");
  • 1
  • 1

雖然知道需要這麼做,但是不知道application/x-www-form-urlencoded表示什麼意思。於是百度學習了下。

二、Form表單語法

在Form元素的語法中,EncType表明提交資料的格式 用 Enctype 屬性指定將資料回發到伺服器時瀏覽器使用的編碼型別。 例如: application/x-www-form-urlencoded: 窗體資料被編碼為名稱/值對。這是標準的編碼格式。 multipart/form-data: 窗體資料被編碼為一條訊息,頁上的每個控制元件對應訊息中的一個部分,這個一般檔案上傳時用。 text/plain: 窗體資料以純文字形式進行編碼,其中不含任何控制元件或格式字元。 
補充

三、常用的編碼方式

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

1.x-www-form-urlencoded

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

2.multipart/form-data

當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)。

OK,簡單學習了。