最近一直都比较忙,坚持月月更新博客的计划不得停止了,今天抽出点时间来讲说最近项目中遇到的一个问题,有关request post请求格式中的multipart/form-data格式。javascript
最近在参与一个项目过程当中遇到一个问题,相信大部分人都遇到过:html
在后端与前端约定好application/json格式传递数据时,由于后台是
go
强类型语言,在定义api接口时,某些字段要求是整型类型,可是对于前端来讲输入框或者从url中的search取到的参数都是字符串,不得不进行前端类型转换。前端
咋一看,对于接口参数比较少的api前端转换没有什么,可是对于通常的交互复杂,参数比较多的接口,要对大部分参数进行类型转换就是一种吃力不讨好的活。好在后端同窗还支持另外一种的先后端数据交互格式,即multipart/form-data
。经过该格式后端取到前端传递的数据就是数字了(即便前端传递的是字符串),而不像json格式获取的是字符串。这样,就不须要额外对前端获取的数据进行特殊转换了。下面就来讲说form-data。java
multipart/form-data
是基于post方法来传递数据的,而且其请求内容格式为Content-Type: multipart/form-data,用来指定请求内容的数据编码格式。另外,该格式会生成一个boundary
字符串来分割请求头与请求体的,具体的是以一个boundary=${boundary}
来进行分割,伪码以下:git
... Content-Type: multipart/form-data; boundary=${boundary} --${boundary} ... ... --${boundary}--
上面boundary=${boundary}
以后就是请求体内容了,请求体内容各字段之间以--${boundary}
来进行分割,以--${boundary}--
来结束请求体内容。具体能够参考下面例子:github
POST http://www.example.com HTTP/1.1 Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryyb1zYhTI38xpQxBK ------WebKitFormBoundaryyb1zYhTI38xpQxBK Content-Disposition: form-data; name="city_id" 1 ------WebKitFormBoundaryyb1zYhTI38xpQxBK Content-Disposition: form-data; name="company_id" 2 ------WebKitFormBoundaryyb1zYhTI38xpQxBK Content-Disposition: form-data; name="file"; filename="chrome.png" Content-Type: image/png PNG ... content of chrome.png ... ------WebKitFormBoundaryyb1zYhTI38xpQxBK--
form-data
格式通常是用来进行文件上传的。使用表单上传文件时,必须让 ajax