form中enctype字段用处(上传文件)

发布时间:2019-10-09编辑:脚本学堂
本文介绍了form表单中enctype字段的用法,在上传文件时,需要设置enctype字段属性,需要的朋友参考下。

form元素的enctype属性指定了表单数据向服务器提交时所采用的编码类型,默认的缺省值是“application/x-www-form-urlencoded”。

这种编码方式在表单发送之前都会将内容进行urlencode 编码。(空格转换为“+”,特殊字符转化为ascii的hex值)。

比如在表单域中的 firstname填入 bb ,,

最后发送之前结果是: bb+%2c%2c

然而,在向服务器发送大量的文本、包含非ascii字符的文本或二进制数据时这种编码方式效率很低。

在文件上载时,所使用的编码类型应当是“multipart/form-data”,它既可以发送文本数据,也支持二进制数据上载。

浏览器端<form>表单的enctype属性值为multipart/form-data,说明传输的数据要用到多媒体传输协议,由于多媒体传输的都是大量的数据,所以规定上传文件必须是post方法,<input>的type属性必须是file。

附,Form标签enctype属性用法实例。

将提交表单的enctype属性设置为了“multipart/form-data”,结果在服务器断的处理文件的request不能直接获取,将“enctype=multipart/form-data”去掉后(即是使用默认的enctype=application/x-www-form-urlencoded),服务器端处理文件中的request就能获取了

W3school对enctype的解释如下:
 

值  描述
application/x-www-form-urlencoded 在发送前编码所有字符(默认)
multipart/form-data 不对字符编码。 在使用包含文件上传控件的表单时,必须使用该值。
text/plain   空格转换为 "+" 加号,但不对特殊字符编码。
 

设置enctype为multipart/form-data值后,不对字符编码,则数据通过二进制的形式传送到服务器端,这时如果用request是无法直接获取到相应表单的值的,而应该通过stream流对象,将传到服务器端的二进制数据解码,从而读取数据。

如果要上传文件的话,是一定要将encotype设置为multipart/form-data的。
如果在服务器端要通过Request对象来获取相应表单域的值,则应该将enctype属性设置为application/x-www-form-urlencoded值(即默认值,可以不显示设置)。