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);

 

 

目录
相关文章
|
1天前
|
数据安全/隐私保护
那些酷炫的网页你也可以做到——第六篇,小型公司web开发
那些酷炫的网页你也可以做到——第六篇,小型公司web开发
|
1天前
|
JavaScript
js中如何使用工厂方式和构造函数创建对象,web开发项目实例
js中如何使用工厂方式和构造函数创建对象,web开发项目实例
|
1天前
|
JavaScript 前端开发 开发者
在Web开发中,事件处理是一个至关重要的概念
【5月更文挑战第17天】Vue.js的事件处理是其核心特性之一,允许开发者响应用户操作。通过v-on(或@)指令绑定DOM事件到方法,实现交互。事件修饰符如.stop、.prevent等简化处理逻辑。此外,Vue支持自定义事件,便于组件间通信,如子组件通过$emit触发事件,父组件使用v-on监听并响应。理解这些机制能帮助开发者更有效地管理Vue应用的事件流程。
9 0
|
1天前
|
前端开发 JavaScript 算法
探索现代Web开发中的前端框架选择
在现代Web开发中,前端框架的选择是至关重要的。本文将深入探讨各种前端框架的特点和适用场景,帮助开发者了解不同框架的优势和劣势,并为他们提供在项目中做出明智选择的指导。
|
JavaScript 前端开发 程序员
好程序员web前端分享用JavaScript实现的5个常见函数
<div id="container"></div> <script> var count = 1 var container = document.getElementById('container') function getUserAction(e) { // 空格 if (e.
795 0
|
3天前
|
设计模式 开发框架 数据库
Python Web开发主要常用的框架
【5月更文挑战第12天】Python Web开发框架包括Django、Flask、Tornado和Pyramid。Django适用于复杂应用,提供ORM、模板引擎等全套功能;Flask轻量级,易于扩展,适合小型至中型项目;Tornado擅长处理高并发,支持异步和WebSockets;Pyramid灵活强大,可适配多种数据库和模板引擎,适用于各种规模项目。选择框架需依据项目需求和技术栈。
120 2
|
1天前
|
设计模式 存储 前端开发
JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发
JS的几种设计模式,Web前端基础三剑客学习知识分享,前端零基础开发
|
1天前
|
存储 安全 前端开发
第五章 跨域资源共享(CORS):现代Web开发中的关键机制
第五章 跨域资源共享(CORS):现代Web开发中的关键机制
|
2天前
|
JSON JavaScript API
使用 Node.js 开发一个简单的 web 服务器响应 HTTP post 请求
使用 Node.js 开发一个简单的 web 服务器响应 HTTP post 请求
9 1
|
2天前
|
JSON JavaScript 中间件
使用 Node.js 开发一个简单的 web 服务器响应 HTTP get 请求
使用 Node.js 开发一个简单的 web 服务器响应 HTTP get 请求
9 2