form表单经常用于前端发送请求,比如:用户填写信息、选择数据、上传文件,对于不同的场景,上传数据的格式也会有些区别。

action

action 表示该请求的 url 地址,定义在form上,请求的URI,可以写完整,也可以以斜线开头,会自动拼接域名端口号。

本地通过 nodejs 在8000端口起了一个服务,当 button 的 type 为 submit 时,点击后会默认发送请求。

<form action="http://127.0.0.1:8000">
       账号: <input name="username">
       密码:<input name="password">
       <button type="submit">提交</button>
</form>

在浏览器中表单就是这样显示的,在账号密码的输入框中分别输入内容

formdata 文件上传file is not present multipart/form-data上传文件及参数_HTTP

点击提交按钮时,会将输入的内容自动拼接在 action 参数之后

formdata 文件上传file is not present multipart/form-data上传文件及参数_上传_02

method

method 属性规定了此次 HTTP 请求的方法。

  • GET 参数直接拼接在 url 后面,默认的形式
  • POST 参数放在请求体中
<form action="http://127.0.0.1:8000" method="post">
       账号: <input name="username">
       密码:<input name="password">
       <button type="submit">提交</button>
 </form>

当使用POST请求时,填写信息点击提交按钮,参数不再拼接到 url 后面,而是放到 body 中,仍然以 & 拼接。

formdata 文件上传file is not present multipart/form-data上传文件及参数_上传文件_03

enctype

enctype 决定着POST请求时,请求体的编码方式。

  • application/x-www-form-urlencoded 不写时默认属性,用&分隔参数,用=分隔键和值,字符用URL编码方式进行编码,GET请求和POST请求都可用
  • multipart/form-data 多用于文件上传,用于POST请求
<form action="http://127.0.0.1:8000" method="post" enctype="multipart/form-data">
       昵称:<input name="nickname">
       头像:<input type="file" name="photo">
       <button type="submit">提交</button>
</form>

填写信息并选择文件

formdata 文件上传file is not present multipart/form-data上传文件及参数_HTTP_04

当请求方法改为 get 时,url 上只拼接了上传文件的名称,没有将文件的具体内容发送到服务器端。

formdata 文件上传file is not present multipart/form-data上传文件及参数_上传_05

当请求方法为 post 时,multipart/form-data 才有着其作用,通过抓包工具追踪的HTTP流来看,请求报文的 Content-Type 中,boundary 后面有一串字符,这个字符就用于拼接用户输入、上传的数据

formdata 文件上传file is not present multipart/form-data上传文件及参数_HTTP_06

而上传的图片信息,将以二进制数据的形式传递

formdata 文件上传file is not present multipart/form-data上传文件及参数_上传文件_07

每一项数据通过两个短横线+ bounary= 后面的字符相隔,这里是----WebKitFormBoundaryBFUEET96fRvnOc3r,服务器获取数据时,通过这个标识来截取即可。

以上就是 文件上传的multipart/form-data属性的内容 , 更多有关 前端网络协议 的内容可以参考我其它的博文,持续更新中~