验证loadrunner对Ajax内容的校验
前一阵和开发的同事一起測试某个系统的性能。此系统是发送Ajax请求到后台,再调用第三方的某项服务。
第三方服务的性能由不得我们控制。因此开发者做了一下改进。超时则直接返回。
于是在loadrunner这边,结果就好看的多了。当时我并没在意,后来一琢磨。这岂不是说loadrunner不检查Ajax内容就通过了?为了验证这个论断,做了个简单的演示样例。
首先是写个前端的html,发送Ajax到后台。再写个servlet处理请求,返回不同的内容。
然后用loadrunner录制脚本并回放,以验证对Ajax内容的检查状况。
新建一个web项目,加入一个html文件和一个servlet
html内容例如以下:
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>用户注冊</title>
</head>
<body>
<script language="JavaScript">
var flag;
function createXHR(){
if (window.XMLHttpRequest){
return new XMLHttpRequest();
}else{
return new ActiveXObject("Microsoft.XMLHTTP");
}
} function checkUser(username){
if(!username==""){
var xhr=createXHR();
xhr.onreadystatechange = function(){
if (xhr.readyState == 4){
if (xhr.status == 200){
var text = xhr.responseText;// 接收返回内容
if (text == "Existed"){
flag = false;
document.getElementById("msg").innerHTML = "用户名反复。无法注冊!";
}else{
flag = true;
document.getElementById("msg").innerHTML = "恭喜。此用户名能够注冊。";
}
}
}
};
//发送用户名到servlet
xhr.open("POST","CheckName?username="+username,true);
xhr.send(null);
document.getElementById("msg").innerHTML = "正在验证……";
}else flag=false;
}
</script> <form action="CheckName" method="post" onsubmit="return flag">
用户名:<input type="text" name="username" onblur="checkUser(this.value)"><span id="msg"></span><br>
密 码:<input type="password" name="password"><br>
<input type="submit" value="注冊">
</form>
</body>
</html>
这是一个简单的模拟注冊的页面,ajax发送输入的用户名到后台。
servlet处理代码例如以下:
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
try {
Thread.sleep(500);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
String username = request.getParameter("username");
PrintWriter out=response.getWriter();
if(username.equals("zhangsan")){
out.print("Existed");
}else{
out.print("Registered Successfully");
} }
当输入的用户是zhangsan时,ajax返回username已存在的标志。除此之外返回能够注冊的提示。(为了模拟网络延时,停顿500毫秒)
loadrunner录制的脚本例如以下:
Action()
{
web_reg_find("Text=用户注冊",LAST); web_url("aaa",
"URL=http://192.168.1.102:8080/aaa/",
"Resource=0",
"RecContentType=text/html",
"Referer=",
"Snapshot=t1.inf",
"Mode=HTML",
LAST); //web_reg_find("Text=Existed",LAST); web_custom_request("CheckName",
"URL=http://192.168.1.102:8080/aaa/CheckName?username=zhangsan",
"Method=POST",
"Resource=0",
"Referer=http://192.168.1.102:8080/aaa/",
"Snapshot=t2.inf",
"Mode=HTML",
"EncType=",
LAST); //web_reg_find("Text=Registered Successfully",LAST); web_custom_request("CheckName_2",
"URL=http://192.168.1.102:8080/aaa/CheckName?username=lisi",
"Method=POST",
"Resource=0",
"Referer=http://192.168.1.102:8080/aaa/",
"Snapshot=t3.inf",
"Mode=HTML",
"EncType=",
LAST); web_submit_data("CheckName_3",
"Action=http://192.168.1.102:8080/aaa/CheckName",
"Method=POST",
"Referer=http://192.168.1.102:8080/aaa/",
"Snapshot=t4.inf",
"Mode=HTML",
ITEMDATA,
"Name=username", "Value=lisi", ENDITEM,
"Name=password", "Value=123456", ENDITEM,
LAST); return 0;
}
凝视中的两行是手工加的,加上后就能够对Ajax返回的内容进行检測了。
验证loadrunner对Ajax内容的校验的更多相关文章
- loadrunner测试ajax框架
loadrunner测试ajax框架的系统时,录制回放都没有报错,但是回放后系统中没有产生数据,解决方法 loadrunnerajax框架测试脚本headerajax [问题描述]用loadrunne ...
- BBS(第一天)项目之 注册功能实现通过forms验证与 前端ajax请求触发查询数据库判断用户是否存在的功能实现
1.BBS项目之注册功能通过forms验证 from django import forms from blog.models import User from django.contrib.auth ...
- ajax实现用户名校验的传统和jquery的$.post方式
第一种:传统的ajax异步请求,后台代码以及效果在最下边 首先我们在eclipse中创建一个注册页面regist.jsp,创建一个form表单,注意,由于我们只是实现用户名校验的效果,下边红色部门是我 ...
- LoadRunner测试AJAX
什么是AJAX? Ajax, shorthand for Asynchronous JavaScript and XML, is a web development technique for cre ...
- ajax案例_校验用户名
目录 ajax案例_校验用户名 代码下载 需求 流程 搭建环境 开发代码 1_jsp 1_servlet 1_service.dao 2_servlet 2_jsp 测试后,功能实现,完结撒花 aja ...
- Atitit 发帖机实现(3 )---usrQBN023 js提交ajax内容到后端规范与标准化
Atitit 发帖机实现(3 )---usrQBN023 js提交ajax内容到后端规范与标准化 大段内容务必要替换转义换行符号1 提交务必使用utf编码,否则解码后的可能缺失,是web serv ...
- 如何让搜索引擎抓取AJAX内容? 转
越来越多的网站,开始采用"单页面结构"(Single-page application). 整个网站只有一张网页,采用 Ajax 技术,根据用户的输入,加载不同的内容. 这种做法的 ...
- 【学习笔记】AJAX内容拓展
题记——近期回顾<javaScript高级程序设计>ajax章节,发现书中对封装一个ajax库并不完美,结合之前看到博客,对ajax库做一点点的优化. 参考博客:如何去封装一个ajax库 ...
- 使用Wisdom RESTClient进行自动化测试,如何取消对返回的body内容的校验?对排除的JSON属性字段不做校验?
使用 Wisdom RESTClient 进行自动化测试 REST API,默认是对返回HTTP状态码和body内容都进行严格匹配和校验. (1). 如果每次触发API返回的body内容是动态变化的, ...
随机推荐
- Leetcode with Python
1. Two Sum Given an array of integers, return indices of the two numbers such that they add up to a ...
- django 修改urls.py 报错误:TypeError: view must be a callable or a list/tuple in the case of include().
#coding=utf-8 from django.conf.urls import include,url from django.contrib import admin from blog im ...
- 2016湖南省赛----G - Parenthesis (括号匹配)
2016湖南省赛----G - Parenthesis (括号匹配) Bobo has a balanced parenthesis sequence P=p 1 p 2…p n of lengt ...
- rsync配置和同步数据
rsync的搭建配置1.环境和配置文件 rsyncd.conf(主配置文件) rsyncd.secrets(密码文件) pc1:192.168.0.1,rsync的服务器,配置rsyncd.conf文 ...
- java异常处理及400,404,500错误处理
java代码中经常碰到各种需要处理异常的时候,比如什么IOException SQLException NullPointException等等,在开发web项目中,遇到异常,我现在做的就 ...
- iOS长按手势调用两次解决方法
由于以前没有很细致的研究过长按手势,所以今天使用的时候发现长按手势会调用两次响应事件. 主要原因是长按手势会分别在UIGestureRecognizerStateBegan和UIGestureReco ...
- 【Luogu】P4234最小差值生成树(LCT)
题目链接 能把LCT打得每个函数都恰有一个错误也是挺令我惊讶的. 本题使用LCT维护生成树,具体做法是对原图中的每个边建一个点,然后连边的时候相当于是将边的起点跟“边”这个点连起来,边的终点也跟它连起 ...
- CSS3的writing-mode属性
writing-mode这个CSS属性以前是IE的独有属性,IE5.5浏览器就已经支持了.在很长一段时间里,FireFox, Chrome这些现代浏览器都不支持writing-mode,各大现代浏览器 ...
- NOIP2012开车旅行 【倍增】
题目 小 A 和小 B 决定利用假期外出旅行,他们将想去的城市从 1 到 N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i 的海拔高度为Hi,城市 i 和城 ...
- 刷题总结——寻宝游戏(bzoj3991 dfs序)
题目: Description 小B最近正在玩一个寻宝游戏,这个游戏的地图中有N个村庄和N-1条道路,并且任何两个村庄之间有且仅有一条路径可达.游戏开始时,玩家可以任意选择一个村庄,瞬间转移到这个村庄 ...