Loadrunner 脚本开发-利用web_submit_data函数实现POST请求

简介: Loadrunner 脚本开发-利用web_submit_data函数实现POST请求

脚本开发-利用web_submit_data函数实现POST请求

 


概述

web_link()web_url()函数都是页面访问型函数,实现HTTP请求中的GET方法,如果需要实现POST方法,可使用web_submit_formweb_submit_data()函数。当请求比较特别,VuGen无法使用以上4个函数时,便会采用web_custom_request()函数。

 

其中,web_submit_form类似web_submit_data函数,不同的是web_submit_data()函数无须引用页面支持,直接发送给对应页面相关数据即可。

 

函数原型(C)

int web_submit_data(const char *StepName, const char *Action, , ITEMDATA, , [ EXTRARES, ,] LAST );

 

StepName:自定义函数名称

 

Action:提交数据时需要访问的http地址。语法:"Action="

 

List of Attributes:支持以下属性

Method:表单提交方法: POSTGET (默认: POST).

 

EncType:方法使用的编码

Enctype属性指明了Content-Type请求头的value值,具体如下:

  • "EncType=application/x–www–form–urlencoded"
  • "EncType=multipart/form–data"  
  • "EncType=" (空字符串,表明请求不含"Content–Type"请求头).

 

如果指定了“EncType”,那么它将会覆盖web_add_[auto_]header函数指定的Content-Type。如果省略了“EncType”时,那么使用web_add_[auto_]header函数指定的。如果既没有指定EncType也没使用web_add_[auto_]header函数设定请求头,且“Method=POST”,那么,将使用“application/x-www-form-urlencoded”做为默认值。如果Method不是POST,那将不会生成Content-Type请求头。

 

EncodeAtSign:编码"@"符号为其ASCII表示.可选值为YesNo.

 

TargetFrame:包含当前链接、资源的frame

 

Referer:所引用web页面的url

 

Mode:录制级别:HTMLHTTP. Click here for more information.

 

UserAgent:标识一个组件替代浏览器来执行函数,比如浏览器的ActiveX组件。函数将为该请求添加UserAgent头。不对该UserAgent是否匹配浏览器User-Agent运行时设置做任何确认检查。

 

ITEMDATA分隔属性列表和和数据列表的标识

 

List of Data:定义了表单数据。data域包含所有隐藏(携带hidden属性)的表单数据。

数据域。

 

数据域的值可以加密后的(encrypted)或者是原始的(plain),如下:

"name=n1", "value=v1", ENDITEM,

"name=n2", "EncryptedValue=qwerty", ENDITEM,

 

EXTRARES:表明接下来的参数为资源属性列表。

 

List of Resource Attributes资源属性列表

当录制在当前脚本的step中时,额外的资源被当作参数列出,支持以下资源属性:

URL      需要加载的web资源

Referer   URL引用的web页面

ENDITEM  表示list中,每个资源结束的标记

 

HTML资源,如.gif.jpg图片,仅在资源录制选项设置为Record within the current script step时,才会插入到当前函数中,如下:

 

 

LAST 暗示属性列表结束。 

action函数,执行"unconditional" or "contextless"表单提交。允许发送GETPOSTHTML表单请求。

 

当选择以HTTP录制模式录制一个WEB会话时,会生成该函数。另外,当表单提交后,无法生成web_submit_form时,也会生成该函数。

1:上传文件

web_submit_data("choujiang",

       "Action=http://xxx.xxx.x.xx:xxx/ditui/fileupload",

       "Method=POST",

       "Resource=0",

       "RecContentType=application/json",

       "Referer=",

       "Mode=HTML",

       "EncType=multipart/form-data",

        ITEMDATA,

        "Name=MultiPart File","Value=E://test_pic.png", "File=yes", ENDITEM,

       LAST);

 

运行结果:

 

 

对比工具测试结果:

 


2:登陆

   web_submit_data("login.pl",

       "Action=http://127.0.0.1:1080/WebTours/login.pl",

       "Method=POST",

       "TargetFrame=body",

       "RecContentType=text/html",

       "Referer=http://127.0.0.1:1080/WebTours/nav.pl?in=home",

       "Snapshot=t3.inf",

       "Mode=HTML",

       ITEMDATA,

       "Name=userSession", "Value=118025.184447145zAHAQcAptcfDztcfpfccff", ENDITEM,

       "Name=username", "Value=jojo", ENDITEM,

       "Name=password", "Value=bean", ENDITEM,

       "Name=JSFormSubmit", "Value=off", ENDITEM,

       "Name=login.x", "Value=58", ENDITEM,

       "Name=login.y", "Value=2", ENDITEM,

       LAST);

 

 

目录
相关文章
|
数据库 开发者 Python
实战指南:用Python协程与异步函数优化高性能Web应用
在快速发展的Web开发领域,高性能与高效响应是衡量应用质量的重要标准。随着Python在Web开发中的广泛应用,如何利用Python的协程(Coroutine)与异步函数(Async Functions)特性来优化Web应用的性能,成为了许多开发者关注的焦点。本文将从实战角度出发,通过具体案例展示如何运用这些技术来提升Web应用的响应速度和吞吐量。
176 1
|
数据库 开发者 Python
实战指南:用Python协程与异步函数优化高性能Web应用
【7月更文挑战第15天】Python的协程与异步函数优化Web性能,通过非阻塞I/O提升并发处理能力。使用aiohttp库构建异步服务器,示例代码展示如何处理GET请求。异步处理减少资源消耗,提高响应速度和吞吐量,适用于高并发场景。掌握这项技术对提升Web应用性能至关重要。
309 10
|
Java Serverless 应用服务中间件
Serverless 应用引擎产品使用合集之Web函数启动的Spring Boot项目可以通过什么方式配置Nginx
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
|
JavaScript 前端开发 索引
【Web 前端】jQuery 里的 each() 是什么函数?你是如何使用它的?
【5月更文挑战第2天】【Web 前端】jQuery 里的 each() 是什么函数?你是如何使用它的?
|
API Python
python flask 提供web的get/post开发
python flask 提供web的get/post开发
225 0
|
前端开发 JavaScript UED
【Web 前端】异步函数
【5月更文挑战第1天】【Web 前端】异步函数
|
前端开发 JavaScript
【Web 前端】$(document).ready() 是个什么函数?为什么要用它?
【5月更文挑战第2天】【Web 前端】$(document).ready() 是个什么函数?为什么要用它?
|
JavaScript 前端开发 C++
【Web 前端】JavaScript window.onload 事件和 jQuery ready 函数有何不同?
【5月更文挑战第2天】【Web 前端】JavaScript window.onload 事件和 jQuery ready 函数有何不同?
|
机器学习/深度学习 运维 网络协议
函数计算产品使用问题之创建一个http服务,可以通过公网来访问,是否只能选择web函数
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
182 0