一般请求中看到 hash strings, random strings, session ID 这种,就需要动态去获取该内容,这样就需要用到关联。

回放时自动关联

1. 录制脚本并执行。

2. 打开“Scan Action for Correlation”窗口,该窗口会询问用户是否要扫描脚本并建立关联,单击“yes”按钮,扫描脚本。

有多种方式可以打开“Scan Action for Correlation”窗口:

  • 方式一:选择 Vuser –> Scan Script for Correlations。
  • 方式二:同时按住 Ctrl + F8 即可调出该窗口。
  • 方式三:执行脚本,执行完毕后系统会自动跳出该窗口。

3. 扫描完后,可以在脚本下方的“Correlation Results”中看到扫描的结果。

4. 检查一下扫描的结果,选择要做关联的数据,然后单击“Correlation”按钮,逐次关联。

这里点击列出的关联条目,可以看到上面以Tree View 的方式对Record 和 Replay 的结果进行比对,方便确定要不要进行关联。

5. 重复步骤1 ~ 步骤4 ,直到所有需要做关联的数据都找出来为止。

手动进行关联方法一:自己写脚本添加关联

背景:

比如你在请求request15的时候需要用到 userid,结果你发现request2的Response里面有userid,那么你要在request2的前面添加关联脚本,假设保存到的参数为userid_result,那么在request15里面就可以直接像使用参数那样使用{userid_result} 。

前提条件

假设页面返回的部分 response 如下:

我们需要获取上面 <title>和 </title>之间的内容,保存到参数 TitleName里面,留着后边用。

那么我们需要在该页面请求的前面添加关联脚本。

添加方法:

1. 鼠标右键,选择 Insert –> New Step。

2. 在 Find Function 中输入 web_reg_save_param_ex,点击OK。

3. 编辑弹出框如下。

Parameter Name:获取的内容要保存到的参数名称,比如这里我想保存到TitleName里面,就输入TitleName。

Left Boundary:左边界。上面看左边界我们可以输入”title>“

Right Boundary:右边界。上面看右边界我们可以输入”</title“

Scope:表示查找范围,比如这里在选择在BODY里面查找。还有其他选项,比如HEADERS、COOKIES

Request URL:表示查找的URL的范围。

4. 点击OK生成脚本。

可以在该页面请求后使用 lr_output_message 打印该参数查看是否正确。

    web_reg_save_param_ex(
"ParamName=TitleName",
"LB=title>",
"RB=</title",
SEARCH_FILTERS,
"Scope=Body",
"RequestUrl=*/www.cnblogs.com/*",
LAST); web_url("www.cnblogs.com",
"URL=http://www.cnblogs.com/",
"Resource=0",
"RecContentType=text/html",
"Referer=",
"Snapshot=t17.inf",
"Mode=HTML",
LAST); lr_output_message("TitleName:%s",lr_eval_string("{TitleName}"));

5. 运行,查看Log

Action4.c(): Registering web_reg_save_param_ex was successful      [MsgId: MMSG-]
Action4.c(): Found resource "http://www.cnblogs.com/bundles/aggsite.css?
.......
Action4.c(): web_url("www.cnblogs.com") was successful, body bytes, header bytes [MsgId: MMSG-]
Action4.c(): TitleName:博客园 - 开发者的网上家园

可以看到正确获取了我们想要的内容。

备注:

感想就是,手动关联一定要想着怎样去界定你要获取的内容,左边界右边界一定要对,然后尽可能的在Filters里面缩小范围就可以。

手动进行关联方法二:在Tree View里面自动建立关联

假设要获取的内容在 “www.cnblogs.com“的response body里面。

方法:

1. 切换到 Tree View视图。

选择 View –> Tree View即可。

2. 选中 Url: www.cnblogs.com

3. 点击HTTP View 查看该链接的 HTTP视图。

4. 点击Response Body查看该请求返回的响应结果。

5. 用鼠标选中要获取的内容,然后点击右键,选择Create Correlation,点击“是”。

6. 切换回脚本视图查看关联是否添加成功。

选择 View –> Script View即可。

//Correlation comment - Do not change!Original value='鍗氬鍥?- 寮€鍙戣€呯殑缃戜笂瀹跺洯' Name ='CorrelationParameter_1'

    web_reg_save_param_ex(
"ParamName=CorrelationParameter_1",
"LB=title>",
"RB=</title",
SEARCH_FILTERS,
"Scope=Body",
"RequestUrl=*/www.cnblogs.com/*",
LAST);

备注

1. 转义字符

左右边界含有特殊字符时,需要用到转义字符“\”。

常见的特殊字符表示如下:

\b 退格
\f 换页
\n 换行
\r 回车
\t 水平制表
\v 垂直制表
\\ 反斜杠
\? 问号字符
\' 单引号字符
\" 双引号字符
\ 空字符

看下面的例子,我需要获取imgId的值:

关联脚本如下:

    web_reg_save_param_ex(
"ParamName=image_id_value",
"LB=imgId\":\"",
"RB=\",",
SEARCH_FILTERS,
"Scope=Body",
"RequestUrl=*/sendimagecode*",
LAST);

2. 如何定位需要关联的地方

可以使用LoadRunner自带的工具 WinDiff来比较脚本的不同,进而找出需要进行关联的地方。

1) 录制两遍脚本,假设分别为 s1 和 s2

2) 使用WinDiff 工具找出两次脚本的不同,判断是否需要进行关联

打开s2,打开 tool –> compare with Script,选择s1。

两个脚本不同的地方 WinDiff 会进行标黄处理。

3)一般两个脚本不同的地方都需要进行关联处理。

lr_think_time表示等待时间,这个不同的话不用管。

4)找到产生该不同文字是在哪个request返回的response里面,我们在该resquest前面添加关联函数即可。

LoadRunner录制:关联的更多相关文章

  1. LoadRunner 录制IE 8卡死

    LoadRunner11录制脚本,对IE的版本是有所限制的,它只是支持IE 8 以下版本,其中包括IE 8,高出IE 8版本Loadrunner是不支持的. 我遇到LoadRunner录制脚本时IE8 ...

  2. 【Loadrunner】Loadrunner 手动关联技术

    Loadrunner 手动关联技术 录制成功,回放失败,怀疑和动态数据有关: 1 重新录制一份脚本,两次录制的脚本进行比对,确定动态数据,复制动态数据: 2  找到第一次产生该动态数据的响应对应的相应 ...

  3. Loadrunner手动关联详解

    Loadrunner手动关联详解 一.关联的含义: 关联(correlation):在脚本回放过程中,客户端发出请求,通过关联函数所定义的左右边界值(也就是关联规则),在服务器所响应的内容中查找,得到 ...

  4. Loadrunner录制脚本之浏览器

    Loadrunner录制脚本之浏览器 用Loadrunner录制脚本,尤其现在的IE浏览器版本升级较快,脚本的录制有时候还是需要集RP.Luck的,当然,Loadrunner对于IE的支持算最好的了, ...

  5. LoadRunner录制Web协议的脚本 (by网络)

    LoadRunner录制Web协议的脚本  http://itindex.net/detail/50530-loadrunner-web-脚本

  6. LoadRunner录制图片验证码

    LoadRunner录制图片验证码 LoadRunner自身是无法捕获到图片验证码的,但是我们可以帮助LoadRunner来实现验证码的捕获. 1.图片验证码 图片验证码的产生来自服务器端,由服务器生 ...

  7. LoadRunner录制不弹出IE浏览器,event=0

    系统环境:win7,安装了IE.360.firefox.搜狗高速浏览器: 起初刚装完loadrunner11的时候,选了IE进行录制,就是不能打开IE,算了,那就用loadrunner默认的设置,居然 ...

  8. loadrunner录制脚本出现urs.asmx解决方法:

    在loadrunner录制过程中可能出现如下脚本: 解决方法: 解决办法:打开IE9的Internet选项-->高级,把设置下面安全中“启用SmartScreen筛选器”不选中,IE默认是选中的 ...

  9. 问题:loadrunner录制event为0

     loadrunner录制问题问题1:录制时出现event为0的状况 解决办法: 1.如果是IE浏览器,把启用第三方浏览器扩展*钩给去掉    2使用火狐浏览器,这个就比较好,在lr启动的时候就去勾选 ...

  10. loadrunner录制、加载以及分析过程

    loadrunner主要组件包括: Virtual User Generator(录制脚本,编写脚本直到调通) Controller(加载脚本,设计并发人数.监控点之类的,模拟场景,开始性能测试,最后 ...

随机推荐

  1. mutiplemap 总结

    之前只是在C++ Primer里面看过关联容器,可能因为没有实际用过,只是看看,所以导致用的时候并不熟悉: 在这之前,map和set的特性应该要了解,map是关联数组,也就是由键值对组成的,而set只 ...

  2. UVALive 6662 TheLastAnt

    #include <iostream> #include <cstdio> #include <cstring> #include <algorithm> ...

  3. PAT甲级1131. Subway Map

    PAT甲级1131. Subway Map 题意: 在大城市,地铁系统对访客总是看起来很复杂.给你一些感觉,下图显示了北京地铁的地图.现在你应该帮助人们掌握你的电脑技能!鉴于您的用户的起始位置,您的任 ...

  4. php 获取所有常量

    有的时候想得到某个完整路径,看看都定义了哪些常量,可以这样做,即把所有的常量都打印出来,然后看看有没有自己想要的,感觉挺方便 官方给的原型: array get_defined_constants ( ...

  5. RN生命周期

    网上看的博客,看着写的很好,想深入学RN的详细看下之后,再自己敲敲吧!有助于身体健康! 一个RN组件从它被加载,到最终被卸载会经历一个完整的生命周期.所谓生命周期,就是一个对象从开始生成到最后消亡所经 ...

  6. ServletActionContext.getRequest().getSession() 和 ActionContext.getContext().getSession()

    ActionContext.getContext().getSession(); 这个方法获取的session是struts封装过的一个Map类型的session,只能调用put()方法缓存数据. S ...

  7. PHP实现文件下载的核心代码

    PHP实现文件下载的核心代码:

  8. erlang debug

    http://www.cnblogs.com/goldli/archive/2011/03/08/1976998.html erlang 模块文件 helloworld.erl 文件内容: -modu ...

  9. HDU 2604 Queuing 矩阵高速幂

    Queuing Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total S ...

  10. java 内存溢出 栈溢出的原因与排查方法

     1. 内存溢出的原因是什么?        内存溢出是由于没被引用的对象(垃圾)过多造成JVM没有及时回收,造成的内存溢出.如果出现这种现象可行代码排查: 一)是否App中的类中和引用变量过多使用了 ...