Web_submit_form和Web_submit_data的区别

时间:2022-02-01 16:18:47

在LoadRunner中有两个常用函数:Web_submit_form和Web_submit_data,在群里有人问这两个函数有什么区别。为什么会有两个不同却功能相似的函数?区别在哪里?

首先,从工具的角度来说,厂商推荐使用Web_submit_form函数,因为这个函数看起来更易用,需要关注的东西较少。但是,从个人的角度来说,我推荐使用Web_submit_data函数,因为这个函数提供更多技术细节,在测试的过程中可控性更高。下面我就详细解释一下两个函数的工作机制:

首先看一下下面这段HTML代码

<Form Action=login.asp Method=“POST”>

<input name=user value=“”>

<input name=password value=“”>

<input type=hidden name=sessionID value=15379>

</Form>

在录制的过程中,当打开这个页面的时候,这个页面会放在LR的Cache中,之后当我们输入了用户名、口令之后,点了一下提交。Browser会向LR Record Proxy发送一个提交请求,提交内容应该是这样的:

POST login.asp HTTP/1.1

user=steve password=buba

sessionID=15379

这时候,LR会自动比较提交的内容和Cache的内容,首先它会比较提交的数据项和Cache中的数据项是否一致。页面中有三个输入域user、password、sessionID,而提交的内容也有这三项数据,所以它认为提交数据使用了Cache中的页面,之后它会继续比较具体数据的值,它会发现sessionID的值和Cache中的值是一样的,但是user和password的值不一样。

这时候,Web_submit_form和Web_submit_data的区别就出现了:

web_submit_form(”start",

ITEMDATA,

"name=user", "value=steve", ENDITEM,

"name=password", "value=bean", ENDITEM,

LAST);

 

web_submit_data(”start",

“Action=login.asp”,

“Method=POST”

ITEMDATA,

"name=user", "value=steve", ENDITEM,

"name=password", "value=bean", ENDITEM,

"name=sessionID", "value=15379", ENDITEM,

LAST);

可以看到,Web_submit_form只提供了和Cache中有差别的数据,其余的数据会自动从Cache中取。而Web_submit_data则提供了所有的数据,不管Cache存在不存在Web_submit_data都是可以工作的。

所以厂商会推荐使用Web_submit_form,因为它看起来更易用,甚至关联都不需要作,就能直接回放。但是这种情况只能对于简单系统适用。对于一些银行或者移动的复杂系统来说,有时侯会对Cache作特殊操作,Web_submit_form有时侯就会报一些莫名其妙的错出来。而Web_submit_data则跟Cache内容无关。稳定性和可控性都要比Web_submit_form要高很多。所以个人推荐尽量使用Web_submit_data函数。