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月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
180 45
|
19天前
|
前端开发 安全 JavaScript
2025年,Web3开发学习路线全指南
本文提供了一条针对Dapp应用开发的学习路线,涵盖了Web3领域的重要技术栈,如区块链基础、以太坊技术、Solidity编程、智能合约开发及安全、web3.js和ethers.js库的使用、Truffle框架等。文章首先分析了国内区块链企业的技术需求,随后详细介绍了每个技术点的学习资源和方法,旨在帮助初学者系统地掌握Dapp开发所需的知识和技能。
2025年,Web3开发学习路线全指南
|
26天前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
29 7
|
1月前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
|
1月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
37 2
|
1月前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
53 1
|
1月前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
存储 测试技术
Loadrunner 脚本开发-利用Loadrunner生成Web service测试脚本
Loadrunner 脚本开发-利用Loadrunner生成Web service测试脚本
138 0
Loadrunner 脚本开发-利用Loadrunner生成Web service测试脚本
|
Java 测试技术 Android开发
Loadrunner脚本开发-基于HTTP协议的流媒体视频在线播放服务器性能测试
Loadrunner脚本开发-基于HTTP协议的流媒体视频在线播放服务器性能测试
160 0
|
XML 存储 测试技术
Loadrunner 脚本开发-soap_request函数介绍及WebService接口测试
Loadrunner 脚本开发-soap_request函数介绍及WebService接口测试
160 0