LoadRunner编写Socket协议脚本⽅法
转载⾃:
本⽂主要介绍使⽤LoadRunner⼿⼯编写Windows Socket协议测试脚本的⽅法。
通过LoadRunner编写Windows Socket协议测试脚本,总体说来,⽐较简单。就像把⼤象放进冰箱⼀样,总共分三步:
第⼀步:把冰箱门打开
//建⽴到服务端的连接
rc =    lrs_create_socket("socket0", "TCP", "LocalHost=0", "RemoteHost=128.64.64.23:8988", LrsLastArg);
if (rc==0)
lr_output_message("Socket  was successfully created ");
else
lr_output_message("An error occurred while creating the socket, Error Code: %d", rc);
第⼆步:把⼤象装进去
lrs_send("socket0", "buf0", LrsLastArg);  //往"socket0"发送"buf0"中的数据
lrs_receive("socket0", "buf1", LrsLastArg);//将"socke0"中返回的数据存放到"buf1"中
第三步:把冰箱门带上
//关闭连接
lrs_close_socket("socket0");
整个脚本关键是在第⼆步,要把这么⼀头⼤象装到冰箱⾥可不是件容易的事情,我们要对传送的数据做⼀些处理才⾏。LR会把你发送的数据包内容写到data.ws这个⽂件中,那么我们在此也同样应该把数据写到data.ws中去。假设我要发送的是“00100312303456”这⼀串字符,那么我就直接把它写到data.ws中,脚本如下:
;WSRData 2 1
send buf0 10
"00100312303456"  //注意要加""
recv buf1 128
-1
运⾏脚本,可以看到执⾏成功。在⽇志信息中可以打印出发送的BUFFER和接收到的BUFFER内容。
接下来,我们要对发送的字符串进⾏参数化,让脚本每次发送的字符串都不⼀样,怎么做呢?有两种⽅法可以实现:
直接参数化。在data.ws中直接进⾏参数化,要注意的是默认的参数名称符号是尖括号(<>),和HTTP协议的⼤括号({})不同。脚本如下:
send buf0 106
"<string>"  //string是⾃定义的参数名
第⼆种⽅法则⿇烦⼀点,下⾯重点做个介绍。
事情是这样的:如果我要发送的数据是很通过简单的⽅法拼接起来,最简单的例⼦,如“⽤户名(假设是123)+密码(假设是456)”,在这种情况下,使⽤第⼀种⽅法就够⽤了,我可以设置两个参数<username>和<password>,写成下⾯的⽅式就可以了。
send buf0 106
"<username><password>"
但是情况稍微复杂⼀些,发送的数据格式还需要加上字符串的长度,⽐如在上⾯的例⼦中,需要这样表⽰:00100312303456。
前四位0010是表⽰后⾯发送的字符串总长度是10,后⾯的03则表⽰⽤户名有3位,再后⾯的123才是真正的⽤户名,再后⾯的03456也是同样的道理。⽽每次发送的⽤户名长度不同,字符串也就不同,⽐如⽤户名如果是1234,那么我的报⽂就应该是这样“001104123403456”这样⼀来,我就不能通过简单地拼接的⽅式来发送了,⽽需要再对它进⾏⼀些处理:
char data[200];
char length[20];
len = strlen(lr_eval_string("{usermame}"));socket通信报文格式
sprintf(length,"%d",len);
strcat(data,length);
strcat(data,"{username}");
//然后,再通过lrs_save_param_ex函数把该数据保存到data_param参数中。
lrs_save_param_ex("socket0", "user", data, 0, strlen(data),NULL, "data_param");
//最后,在data.ws⽂件中使⽤data_param参数发送数据包:send buf0 "<data_param>"

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。