jquery ajax post提交数据_常见Post提交数据方式接口测试 - Z_sun

 1.说明

HTTP/ 协议规定的 HTTP 请求方法有 OPTIONS、GET、HEAD、POST、PUT、DELETE、TRACE、CONNECT 这几种。其中 POST 一般用来向服务端提交数据,本文主要讨论 POST 提交数据的几种方式。

我们知道,HTTP 协议是以 ASCII 码传输,建立在 TCP/IP 协议之上的应用层规范。规范把 HTTP 请求分为三个部分:状态行、请求头、消息主体。

2.四种常见的POST提交数据方式

说明:enctype 属性规定在发送到服务器之前应该如何对表单数据进行编码。默认地,表单数据会编码为 "application/x-www-form-urlencoded"。就是说,在发送到服务器之前,所有字符都会进行编码(空格转换为 "+" 加号,特殊符号转换为 ASCII HEX 值)

(一)Content-Type:application/x-www-form-urlencode

最常见的 POST 提交数据的方式了。浏览器的原生 <form> 表单,如果不设置 enctype 属性,那么最终就会以 application/x-www-form-urlencoded 方式提交数据。

其次,提交的数据按照 key1=val1&key2=val2  的方式进行编码,key 和 val 都进行了 URL 转码。

数据写在jmeter的 “Body Data” 中。

A:jmeter中测试接口

075deda8209a7d4ecb4ddcfa75776be7.png

ba35b2c8a5d4ce31ed443d511bebf8e6.png

 输入参数为 " [ json=...&base=...] "

 B: Fiddle中

Content-Type:application/x-www-form-urlencoded

75f2b26ca1232e30725357520b8fc1c4.png

(二)Content-Type:multipart/formdata

这种数据提交方式主要用来上传文件的。

传输的数据写在jmeter的 “Parameters” 和 “Files Upload (要上传的文件)” 中。

A:jmeter中测试接口

b76e17fdbd724355ea61cc10ecbcf464.png

a23f98e0ad33cec823b236430d4cfd70.png1098dbb8b98782d3f1b02f6c8122514b.png

 B: Fiddle中

 f3e53d66860cc72fbd5cf8a877e51292.png

(因为该接口传入数据需要转码传入,不需要的可以忽略该步骤)

6659b469735bc090d19e45abd4baa96b.png

先Upload file 上传自己要上传的文件,信息如下:

---------------------------acebdf13572468

Content-Disposition: form-data; name="fieldNameHere"; filename=""

Content-Type: application/pdf

<@INCLUDE *E:\ceshi1\*@>

---------------------------acebdf13572468--

补充完整发送的参数:(每一部分之间空格必须存在)

Content-Type: multipart/form-data; boundary=-------------------------acebdf13572468

User-Agent: Fiddler

Host: www.quceba.com:8080

Content-Length: 161109 

---------------------------acebdf13572468

Content-Disposition: form-data; name="pdf"; filename=""

Content-Type: application/octet-stream

<@INCLUDE *E:\ceshi1\*@>

---------------------------acebdf13572468

Content-Disposition: form-data; name="json"

Content-Type: text/plain ; charset=UTF-8

%7b%22sign%22%3a%7b%22ID%22%3a%2219ff226ef7ff407898b5372b661e7435%22%7d%7d

---------------------------acebdf13572468--

(三)Content-Type:application/json

Content-Type:application/json 作为请求头,用来告诉服务端消息主体是序列化后的 JSON 字符串。

数据写在jmeter的 “Body Data” 中。

A:jmeter中测试接口

1f700ed7f57ee3d3ce06ffb3f8628234.png 98e974927ef489c7a75f1b6cf10430b6.png

 (四)Content-Type:text/xml

 XML-RPC(XML Remote Procedure Call),它是一种使用 HTTP 作为传输协议,XML 作为编码方式的远程调用规范。

典型的 XML-RPC 请求是这样的: 

POST http://www.example.com HTTP/ Content-Type: text/xml 

<!--?xml version=""?--> <methodcall>     <methodname>     <params>         <param>             <value><i4>41</i4></value>              </params> </methodcall> XML-RPC 协议简单、功能够用,各种语言的实现都有。它的使用也很广泛,如 WordPress 的 XML-RPC Api,搜索引擎的 ping 服务等等。JavaScript 中,也有现成的库支持以这种方式进行数据交互,能很好的支持已有的 XML-RPC 服务。不过,我个人觉得 XML 结构还是过于臃肿,一般场景用 JSON 会更灵活方便。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值