HTML 表单中的含义是什么,enctype=’multipart/form-data’我们应该什么时候使用它?
当您发出 POST 请求时,您必须以某种方式对构成请求正文的数据进行编码。
HTML 表单提供了三种编码方法。
application/x-www-form-urlencoded
multipart/form-data
text/plain
正在完成添加的工作application/json,但已被放弃。
application/json
(使用 HTML 表单提交之外的其他方式生成的 HTTP 请求也可以使用其他编码。JSON 是用于 Web 服务的常用格式,有些仍然使用 SOAP。)
格式的细节对大多数开发人员来说并不重要。重点是:
当您编写客户端代码时:
<input type="file">
在编写服务器端代码时:
大多数(例如 PerlCGI->param或 PHP 的$_POSTsuperglobal 所公开的)将为您处理差异。不要费心尝试解析服务器接收到的原始输入。
CGI->param
$_POST
有时你会发现一个库不能同时处理这两种格式。Node.js 最流行的处理表单数据的库是body-parser,它不能处理多部分请求(但有文档推荐了一些可以的替代方案)。
如果您正在编写(或调试)用于解析或生成原始数据的库,那么您需要开始担心格式。出于兴趣,您可能还想了解它。
application/x-www-form-urlencoded或多或少与 URL 末尾的查询字符串相同。
multipart/form-data复杂得多,但它允许将整个文件包含在数据中。可以在HTML 4 规范中找到结果示例。
text/plain由 HTML 5 引入,仅对调试有用——从规范来看:它们不能被计算机可靠地解释——我认为其他与工具相结合的工具(如大多数浏览器的开发人员工具中的网络面板)更好为了那个原因)。