常见的POST提交方式

HTTP 协议是基于TCP/IP协议之上的应用层规范,规范将 HTTP 请求分为三部分: 请求行、请求头、消息体。整体类似于:

<method> <request-URL> <version>   // 请求行

<headers>  // 请求头

<entity-body>  // 协议体

协议规定 POST 请求的参数必须放在协议体中,但我们在请求头中设置消息主体的协议格式。服务端通常是根据请求头(headers)中的 Content-Type 字段来获知请求中的消息主体是用何种方式编码,再对主体进行解析。所以说到 POST 提交数据方案,包含了 Content-Type 和消息主体编码方式两部分。下面就正式开始介绍它们。

 

一、application/x-www-form-urlencoded


常见的 POST 请求提交方式,请求头类似于

大部分服务器端都对这种提交方式有很好的支持,例如 JQuery 和 QWrap 的 Ajax,Content-Type 默认值都是「application/x-www-form-urlencoded;charset=utf-8」

 

二、multipart/form-data


通常上传文件需要将 Content-Type 设为 multipart/form-data。前端使用 formData对象来加入文件

var form = new FormData();
form.append('iid', '2');
form.append('test', '2');
form.append('file', cfg.Obj, cfg.Name);

 

三、application/json


application/json 这个 Content-Type 作为响应头大家肯定不陌生。实际上,现在越来越多的人把它作为请求头,用来告诉服务端消息主体是序列化后的 JSON 字符串。由于 JSON 规范的流行,除了低版本 IE 之外的各大浏览器都原生支持 JSON.stringify,服务端语言也都有处理 JSON 的函数,使用 JSON 不会遇上什么麻烦。

JSON 格式支持比键值对复杂得多的结构化数据,这可以让我们直接传递 JSON 对象给服务器。axios 中的 post 方法就是默认使用 application/json 方式提交的。


var infoForm = {
    'u': xxxxxx
}
this.$post('xxxxxxx/gettest', infoForm)
    .then((response) => {
        ....
    })
    .catch(function (error) {
         console.log(error);
    });

 

四、text/xml


text/xml 是一种使用 HTTP 作为传输协议,XML 作为编码方式的远程调用规范。典型的 XML-RPC 请求是这样的:

POST http://www.example.com

HTTP/1.1 Content-Type: text/xml

<?xml version="1.0"?>

<methodCall>

     <methodName>examples.getStateName</methodName>

     <params> <param>

     <value><i4>41</i4></value>

</param> </params> </methodCall>

text/xml 过于臃肿,一般场景使用 JSON 会更加灵活

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值