基于Ajax技术实现考试倒计时并自动提交试卷
1.概述
在开发网络考试系统时,考试计时并自动提交试卷是必不可少的功能。由于在答卷过程中,试卷不能刷新,所以需要使用Ajax实现无刷新操作。运行本实例,访问准备考试页面index.jsp,在该页面中,单击“开始考试”按钮,将打开新窗口显示开始考试的页面,如图10.1所示,页面会自动计时,当考试时间结束时,将自动提价试卷。
2.技术要点
主要是利用Ajax异步提交技术和Servlet技术实现的。显示在考试页面中的计时时间是在Servlet中设置的,需要通过Ajax的异步提交不断的请求Servlet,从而获得服务器返回的最新的计时时间的数据。为了便于维护和代码的重用,可以将Ajax的请求方法封装到一个JS文件中,该方法可以作为一个公共方法,在程序中使用时可以直接调用。
3.具体实现代码
在JS文件中构建XMLHttpRequest对象以及请求方法,如下代码所示:
/**
*构建XMLHttpRequest对象并请求服务器
*@paramreqType:请求类型(GET或POST)
*@paramurl:服务器地址
*@paramasync:是否异步请求
*@paramresFun:响应的回调函数
*@paramparameter:请求参数
*@return:XMLHttpRequest对象
*/
functionhttpRequest(reqType,url,async,resFun,parameter){
varrequest=null;
if(window.XMLHttpRequest){//非IE浏览器,创建XMLHttpRequest对象
request=newXMLHttpRequest();
}elseif(window.ActiveXObject){//IE浏览器,创建XMLHttpRequest对象
vararrSignatures=["Msxml2.XMLHTTP","Microsoft.XMLHTTP","Microsoft.XMLHTTP","MSXML2.XMLHTTP.5.0","MSXML2.XMLHTTP.4.0","MSXML2.XMLHTTP.3.0","MSXML2.XMLHTTP"];
for(vari=0;i<arrSignatures.length;i++){
request=newActiveXObject(arrSignatures[i]);
if(request||typeof(request)=="object")
break;
}
}
if(request||typeof(request)=="object"){
if(reqType.toLowerCase()=="post"){//以POST方式提交
request.open(reqType,url,true);//打开服务器连接
//设置MIME类型
request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
request.onreadystatechange=resFun;//设置处理响应的回调函数
parameter=encodeURI(parameter);//将参数字符串进行编码
request.send(parameter);//发送请求
}
else{//以GET方式提交
url=url+"?"+parameter;
request.open(reqType,url,true);//打开服务器连接
request.onreadystatechange=resFun;//响应回调函数
request.send(null);//发送请求
}
}
else{
alert("该浏览器不支持Ajax!");
}
returnrequest;
}
(1)新建index.jsp页,该页面是用户访问的初始页。在页面中主要包含一个“开始考试”按钮,该按钮的onclick事件将调用打开考试窗口的JavaScript函数,关键代码如下:
functionshowWindow(){window.open('StartExam?action=startExam','','width=750,height=500,scrollbars=1');
}
(2)新建名为StartExam的Servlet实现类,该类用创建考试的开始时间和剩余时间。在该类中,创建一个全局变量examTime,用于记录考试时间,该变量的值是在web.xml中设置的,关键代码如下:
<servlet> <servlet-name>StartExam</servlet-name> <servlet-class>com.lh.servlet.StartExam</servlet-class> <init-param> <param-name>examTime</param-name> <param-value>20</param-value> </init-param> </servlet>
(3)在StartExam类中,编写用于将页面转发到开始考试页面的方法startExam()。关键代码如下:
publicvoidstartExam(HttpServletRequestrequest,HttpServletResponseresponse)
throwsServletException,IOException{
HttpSessionsession=request.getSession();
request.setAttribute("time",examTime);//保存考试时间
session.setAttribute("startTime1",newDate().getTime());//保存当前时间的毫秒数
request.getRequestDispatcher("startExam.jsp").forward(request,response);
}
(4)新建showStartTime.jsp页,用于输出计时开始时间。关键代码如下:
<%@pagecontentType="text/html"pageEncoding="GBK"%>
${showStartTime}
(5)新建showRemainTime.jsp页,用于输出计时剩余时间。关键代码如下:
<%@pagecontentType="text/html"pageEncoding="GBK"%>
${showRemainTime}
(6)新建开始考试页面startExam.jsp页,在该页中通过调用Ajax请求方法请求StartExam类,获得考试的开始时间和剩余时间。关键代码如下:
varrequest1=false;
varrequest2=false;
//请求Servlet获得开始时间
functionshowStartTime(){
varurl="StartExam";
//此处需要加&nocache="+newDate().getTime(),否则将出现时间不自动走动的情况
varparameter="action=showStartTime&nocache="+newDate().getTime();
request1=httpRequest("post",url,true,callbackFunc,parameter);
}
//回调函数
functioncallbackFunc(){
if(request1.readyState==4){
if(request1.status==200){
showStartTimediv.innerHTML=request1.responseText;
}
}
}
//请求Servlet获得剩余时间
functionshowRemainTime(){
varurl="StartExam";
varparameter="action=showRemainTime&nocache="+newDate().getTime();
request2=httpRequest("post",url,true,callbackFunc_R,parameter);
}
//回调函数
functioncallbackFunc_R(){
if(request2.readyState==4){
if(request2.status==200){
h=request2.responseText;
showRemainTimediv.innerHTML=h;
h=h.replace(/\s/g,"");//去除字符串中的Unicode空白符
showRemainTimediv.innerHTML=h;
if(h=="00:00:00"){
form1.submit();
}
}
}
}
(7)为了实现页面加载后自动计时,需要在开始考试页面的<body>标签中通过onload事件应用window.setInterval()方法调用showStartTime()函数和showRemailTime()函数,关键代码如下:
<bodyonLoad="showStartTime();showRemainTime();"onkeydown="keydown()">
以上所述是小编给大家介绍的基于Ajax技术实现考试倒计时并自动提交试卷的相关知识,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!