分享编程~
 

数据传输POST 提交数据常用几种方式

HTTP 请求方法有常用的POST数据提交方式有多种,常见form 表单方式、文件数据流、json、xml等。

天天特卖抢好货

HTTP 协议是以 ASCII 码传输,建立在 TCP/IP 协议之上的应用层规范。规范把 HTTP 请求分为三个部分:状态行、请求头、消息主体。类似于下面这样:

<method><request-url> <version><headers><entity-body></entity-body></headers></version></request-url></method>

HTTP/1.1 协议规定的 HTTP 请求方法有 OPTIONS、GET、HEAD、POST、PUT、DELETE、TRACE、CONNECT 这几种。其中 POST 一般用来向服务端提交数据,协议规定 POST 提交的数据必须放在消息主体(entity-body), POST 提交数据包含了 Content-Type 和消息主体编码方式两部分,POST常用提交方式有以下四中:

一、application/x-www-form-urlencoded

原生 form 表单默认方式:application/x-www-form-urlencoded 方式提交数据

POST http://www.yj521.com HTTP/1.1
Content-Type: application/x-www-form-urlencoded;charset=utf-8
title=测试&id=1

Content-Type 为 application/x-www-form-urlencoded;提交的数据按照 key1=val1&key2=val2 的方式进行编码,key 和 val 都进行了 URL 转码。大部分服务端语言都对这种方式有很好的支持。例如 PHP 中,$_POST['title'] 可以获取到 title 的值。

用 Ajax 提交数据时,也是使用这种方式。例如 JQuery 和 QWrap 的 Ajax,Content-Type 默认值都是「application/x-www-form-urlencoded;charset=utf-8」。

二、multipart/form-data

表单上传文件时, form 的 enctyped 必须设置为当前这个值。这种方式一般用来上传文件,各大服务端语言对它也有着良好的支持。

示例:

POST http://www.yj521.com HTTP/1.1
Content-Type:multipart/form-data; boundary=----WebKitFormBoundaryrGKCBY
 
------WebKitFormBoundaryrGKCBY7qhFd3TrwA
Content-Disposition: form-data; name="text"
 
title
------WebKitFormBoundaryrGKCBY7qhFd3TrwA
Content-Disposition: form-data; name="file"; filename="chrome.png"
Content-Type: image/png
 
PNG ... content of chrome.png ...
------WebKitFormBoundaryrGKCBY7qhFd3TrwA--

三、application /json

序列化后的 JSON 字符串格式,JSON 格式支持比键值对复杂得多的结构化数据,方便提交复杂的数据,特别适合 RESTful 的接口。

示例:


var data = {'title':'test', 'sub' : [1,2,3]};
$http.post(url, data).success(function(result) {
    ...
});

请求的数据是:

POST http://www.yj521.com HTTP/1.1
Content-Type: application /json;charset=utf-8
 
{"title":"test","sub":[1,2,3]}

各大抓包工具如 Chrome 自带的开发者工具、Firebug、Fiddler,都会以树形结构展示 JSON 数据,非常友好。但也有些服务端语言还没有支持这种方式,例如 php 就无法通过 $_POST 对象从上面的请求中获得内容。这时候,需要自己动手处理下:在请求头中 Content-Type 为application /json时,从 php://input 里获得原始输入流,再 json_decode 成对象。一些 php 框架已经开始这么做了。json也可以用x-www-form-urlencoded方式提交,数据字符过长就显得不合适了。

四、text/xml

XML-RPC(XML Remote Procedure Call)XML-RPC消息就是一个请求体为xml的http-post请求:

POST http://www.yj521.com HTTP/1.1
Content-Type: text/xml
 
<!--?xml version="1.0"?-->
<methodcall>
    <methodname>statusCode</methodname>
    <params>
        <param>
            <value><i4>521</i4></value>
         
    </params>
</methodcall>

XML-RPC 协议简单、功能够用,各种语言的实现都有。它的使用也很广泛,如 WordPress 的 XML-RPC Api,搜索引擎的 ping 服务等等。JavaScript 中,也有现成的库支持以这种方式进行数据交互,能很好的支持已有的 XML-RPC 服务。 XML 结构还是过于臃肿,一般场景用 JSON 会更灵活方便。


上一篇:jQuery异步加载Ajax简单分页插件示例下一篇:纯Javascript图表插件 Highcharts封装调用示例
赞(2) 踩(0)
您说多少就多少,您的支持是我最大的动力
赏金
微 信
赏金
支付宝
本文连接: https://www.yj521.com/article/100.html
版权声明: 本文为原创文章,版权归《越加网》所有,分享转载请注明出处!