在HTTP协议中并没有规定POST请求的数据要采用编码何种方式,从某种程度上说,这种编码方式可以是自定义的,可以是任意的。
当然,这种编码是需要和服务器有一个合适的约定,这样服务器端才能正确的解码得到的数据。通常来说,服务器是根据request中的header中的Content-Type来获取传送的数据是采用何种编码方式。
就常见的语言来说,一般会内置下面几个常见编码方式的解析。
1.application/x-www-form-urlencoded
在form表单中,默认的情况就是这种enctype属性。也就是说,如果不显式的指定form表单post数据的编码方式的话,就会是以默认的application/x-www-form-urlencoded编码方式传输数据。
在Jquery中,进行Ajax提交数据的时候默认也是这种编码方式。
2. multipart/form-data
这种编码方式也是极其常见的,主要表现在利用表单来传输文件的时候。
通常是这样书写:
<FORM ENCTYPE="multipart/form-data" ACTION="_URL_" METHOD=POST>
File to process: <INPUT NAME="userfile1" TYPE="file">
<INPUT TYPE="submit" VALUE="Send File">
</FORM
3. application/json
这种编码方式在支持上就没有前面两种强悍了,但由于通常情况下语言对Json的序列化都做的很好,我们可以自行的获取数据流,然后做decode操作就能得到一个json式的对象,极其方便的去进行数据操作。
当然语言支持不好不代表框架支持也不好,很多主流的框架也已经开始使用这种方式了。
当然,真心觉得不好用的话也可以把得到的Json数据变成一个字符串,然后用application/x-www-form-urlencoded的方式编码,后台得到后再解析为json对象
4. text/xml
相比Json而言,他的出现更早,在早期的使用上也更为广泛,各种语言对他的解析也是相当不错。不过近年来的json风也让他有了很大程度上的衰落。
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。