loadrunner 脚本开发- web_url函数详解

简介: loadrunner 脚本开发- web_url函数详解

脚本开发- web_url函数详解

 

加载指定urlweb页面(GET请求)

 

C语言函数

int web_url( const char *StepName, const char *url, , [EXTRARES, ,] LAST );

 

java语言

int object.url( String stepName, String url, String[] argumentList );

 

Argument

Description

object

WebApi类型的对象表达式。对于JavaVB来说,通常是Web

StepName

图形脚本中的step标签。如果开启了Automatic Transactions(自动化事务),则它同时也是事物名称。

URL

需要加载的Web页面的URL(Uniform Resource Locator),格式为:"URL=

"

List of Attributes

属性列表

EXTRARES

划界参数,标识下一个参数将是资源列表.

List of Resource Attributes

资源属性列表

LAST

标识参数列表结束的标记。

 

web_url仅在VuGen处于URL-based script或者勾选A script containing explicit URLs onlyHTML-based scripte模式下被录制。(VuGen的录制选项Recording Options).

 

可使用web_url模拟从FTP服务器下载文件。下载是基于二进制模式完成的,除非指定"FtpAscii=1"

 

non-HTML-generated资源,如gif,jmagegs. List of Resource Attributes仅在录制选项中设置了Record within the current script step才会被插入。

 




函数适用所有Web脚本,运行于HTTP模式或者无线会话协议(WSP)模式的脚本

 

List of Attributes

FtpAscii - "1"ASCII模式下执行FTP传输,"0" for binary mode.

 

TargetFrame -包含当前连接、资源的框架名称。

 

RecContentType -录制期间响应应头(RESPONSE header)内容类型(content–type),text/html, application/x–javascript。用于判断目标URL是否为一个可录制资源。

 

Referer - URL引用的页面。

 

Resource -一个标识URL是否是资源的值:

0 – URL is not a resource
1 – the URL is a resource

 

Snapshot -快照文件(inf extension)的文件名

 

Mode -录制级别: HTML or HTTP.

 

UserAgent -用户代理头,随请求一起发送。这里不会对该参数是否和运行时设置中射的浏览器User-Agent是否一致匹配。.

例子:

   web_url("www.phpwind.net",

       "URL=http://www.phpwind.net/",

       "TargetFrame=",

       "Resource=0",

       "RecContentType=text/html",

       "Referer=",

       "Snapshot=t14.inf",

       "Mode=HTML",

       EXTRARES,

       "Url=/themes/site/link2015/images/common/navBbg.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/headbg.png", ENDITEM,

       "Url=/themes/site/link2015/images/forum/new.gif", ENDITEM,

       "Url=/themes/site/link2015/images/design/mode_h_bg.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/search.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/nav_cur.png", ENDITEM,

       "Url=/themes/site/link2015/images/forum/old.gif", ENDITEM,

       "Url=/themes/site/link2015/images/common/nav_hover.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/head_icon.png", ENDITEM,

       "Url=/res/js/dev/jquery.js?v=20141124", ENDITEM,

       "Url=http://c.cnzz.com/core.php?web_id=30051218&t=q", ENDITEM,

       "Url=/themes/site/link2015/images/common/core_bg.png", ENDITEM,

       "Url=/res/js/dev/pages/common/global.js?v=20141124", ENDITEM,

       "Url=/res/js/dev/ui_libs/tabs/tabs.js?v=20141124", ENDITEM,

       LAST);

 

关于EXTRARES的说明:

   EXTRARES,

       "Url=/themes/site/link2015/images/common/navBbg.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/headbg.png", ENDITEM,

       "Url=/themes/site/link2015/images/forum/new.gif", ENDITEM,

       "Url=/themes/site/link2015/images/design/mode_h_bg.png", ENDITEM,

       "Url=/themes/site/link2015/images/common/search.png", ENDITEM,

……

 

以上这一段内容说明在载入这个页面时还有其它图片或附属资源需要下载。由于默认的web_urlweb_link函数是使用HTML Mode的,所以无论脚本中是否存在EXTRARES段,在完成函数的时候都会自动下载该HTML对应的所有资源。EXTRARES段是一种扩展验证机制,验证这些对象是否存在,如果EXTRARES中的资源请求并存在请求返回内,那么回放该脚本会比真实情况略微增加带宽的使用。

 

扩展:

1)如果EXTRARES段中请求的地址和主请求相同,则不会产生新的流量

2)录制得到的EXTRARES不是简单地将图片拆出,而是主请求请求不到的内容,例如css中的图片引用或favicon.ico

3)错误的EXTRARES会产生额外的请求。

 

在普通脚本开发中为了更好地模拟用户请求,最好别删EXTRARES段,多了没啥坏处,只是多了一点数据流量,删除了会导致某些主请求请求不到的内容不会被请求。

 

官网例子:

Example 1 –发送一个访问abc.comHTTP GET请求。

web_url("www.abc.com",

"URL=http://www.abc.com/",

"TargetFrame=",

"TargetBrowser=Mercury Technologies",

"Resource=0",

"RecContentType=text/html",

"Snapshot=t1.inf",

"Mode=HTML",

LAST );

 

Example 2 –发送一个带引用页面的请求

web_url("Hit the Slopes and Save",

"URL=http://www.saleserver.com/American?BV_EngineID=

..fm_ski_sale_fall00guest.html",

"TargetFrame=Main",

"Resource=0",

"RecContentType=text/html",

"Referer=http://www.saleserver.com/American?BV_Operation=
Dyn_Frame&..main–guest.tmpl",

"Snapshot=t3.inf",

"Mode=HTML",

LAST );

 

Example 3–下载一个ftp服务器上的游戏

web_url("Games",

"URL=ftp://joe:secret@mygames.com/games/archive/loderunner.exe",

"FtpAscii=1",

LAST );

 

Example 4–登陆到一个安全站点

web_url("Login",

"URL=https://secure.computing.com/scripts/login.asp?
user=(username)&session={ssid}",

"RecContentType=text/html", //Expected content–type

 

 

目录
相关文章
|
3月前
|
Java
Java开发实现图片URL地址检验,如何编码?
【10月更文挑战第14天】Java开发实现图片URL地址检验,如何编码?
124 4
|
3月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
217 3
|
2月前
|
开发框架 搜索推荐 数据可视化
Django框架适合开发哪种类型的Web应用程序?
Django 框架凭借其强大的功能、稳定性和可扩展性,几乎可以适应各种类型的 Web 应用程序开发需求。无论是简单的网站还是复杂的企业级系统,Django 都能提供可靠的支持,帮助开发者快速构建高质量的应用。同时,其活跃的社区和丰富的资源也为开发者在项目实施过程中提供了有力的保障。
138 62
|
1月前
|
前端开发 安全 JavaScript
2025年,Web3开发学习路线全指南
本文提供了一条针对Dapp应用开发的学习路线,涵盖了Web3领域的重要技术栈,如区块链基础、以太坊技术、Solidity编程、智能合约开发及安全、web3.js和ethers.js库的使用、Truffle框架等。文章首先分析了国内区块链企业的技术需求,随后详细介绍了每个技术点的学习资源和方法,旨在帮助初学者系统地掌握Dapp开发所需的知识和技能。
2025年,Web3开发学习路线全指南
|
2月前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
239 45
|
2月前
|
存储 前端开发 JavaScript
如何在项目中高效地进行 Web 组件化开发
高效地进行 Web 组件化开发需要从多个方面入手,通过明确目标、合理规划、规范开发、加强测试等一系列措施,实现组件的高效管理和利用,从而提高项目的整体开发效率和质量,为用户提供更好的体验。
46 7
|
2月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
53 2
|
2月前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
68 1
|
2月前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
2月前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
89 2