Ajax技术--考试计时并自动提交试卷

Posted 柯南&

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Ajax技术--考试计时并自动提交试卷相关的知识,希望对你有一定的参考价值。

1.概述

     在开发网络考试系统时,考试计时并自动提交试卷是必不可少的功能。由于在答卷过程中,试卷不能刷新,所以需要使用Ajax实现无刷新操作。运行本实例,访问准备考试页面index.jsp,在该页面中,单击“开始考试”按钮,将打开新窗口显示开始考试的页面,如图10.1所示,页面会自动计时,当考试时间结束时,将自动提价试卷。

 

2.技术要点

     主要是利用Ajax异步提交技术和Servlet技术实现的。显示在考试页面中的计时时间是在Servlet中设置的,需要通过Ajax的异步提交不断的请求Servlet,从而获得服务器返回的最新的计时时间的数据。为了便于维护和代码的重用,可以将Ajax的请求方法封装到一个JS文件中,该方法可以作为一个公共方法,在程序中使用时可以直接调用。

 

3.具体实现代码

在JS文件中构建XMLHttpRequest对象以及请求方法,如下代码所示:

/**
 * 构建XMLHttpRequest对象并请求服务器
 * @param reqType:请求类型(GET或POST)
 * @param url:服务器地址
 * @param async:是否异步请求
 * @param resFun:响应的回调函数
 * @param parameter :请求参数
 * @return :XMLHttpRequest对象
 */
function httpRequest(reqType,url,async,resFun,parameter){     
      var request = null;
      if( window.XMLHttpRequest ){                  //非IE浏览器,创建XMLHttpRequest对象
            request = new XMLHttpRequest();
      }else if( window.ActiveXObject ){                     //IE浏览器,创建XMLHttpRequest对象
            var arrSignatures = ["Msxml2.XMLHTTP", "Microsoft.XMLHTTP", "Microsoft.XMLHTTP", "MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0", "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP"];       
            for( var i = 0; i < arrSignatures.length; i++ ){
                  request = new ActiveXObject( 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!" );
      }    
      return request;
}

(1)新建index.jsp页,该页面是用户访问的初始页。在页面中主要包含一个“开始考试”按钮,该按钮的onclick事件将调用打开考试窗口的javascript函数,关键代码如下:

function showWindow(){                                                                                                                                                                                              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()。关键代码如下:

public void startExam(HttpServletRequest request,HttpServletResponse response)
        throws ServletException,IOException{
        HttpSession session = request.getSession();
        request.setAttribute("time", examTime);                 //保存考试时间
        session.setAttribute("startTime1",new Date().getTime());   //保存当前时间的毫秒数
        request.getRequestDispatcher("startExam.jsp").forward(request, response);
}

(4)新建showStartTime.jsp页,用于输出计时开始时间。关键代码如下:

<%@page contentType="text/html" pageEncoding="GBK"%>
${showStartTime}

(5)新建showRemainTime.jsp页,用于输出计时剩余时间。关键代码如下:

<%@page contentType="text/html" pageEncoding="GBK"%>
${showRemainTime}

(6)新建开始考试页面startExam.jsp页,在该页中通过调用Ajax请求方法请求StartExam类,获得考试的开始时间和剩余时间。关键代码如下:

     var request1= false;
            var request2 = false;
            //请求Servlet获得开始时间 
            function showStartTime(){
                  var url = "StartExam";
                  //此处需要加&nocache="+new Date().getTime(),否则将出现时间不自动走动的情况
                  var parameter="action=showStartTime&nocache="+new Date().getTime();
                  request1 = httpRequest("post",url,true,callbackFunc,parameter);  
            }
            //回调函数 
            function callbackFunc(){
                  if( request1.readyState==4 ){ 
                    if( request1.status == 200 ){
                                showStartTimediv.innerHTML=request1.responseText;
                        }
                  }
            }
            //请求Servlet获得剩余时间 
            function showRemainTime(){
                  var url = "StartExam";
                  var parameter="action=showRemainTime&nocache="+new Date().getTime();
                  request2 = httpRequest("post",url,true,callbackFunc_R,parameter);     
            }
            //回调函数 
            function callbackFunc_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()函数,关键代码如下:

<body onLoad="showStartTime();showRemainTime();" onkeydown="keydown()">

 

以上是关于Ajax技术--考试计时并自动提交试卷的主要内容,如果未能解决你的问题,请参考以下文章

基于PHP+MYSQL的在线考试系统

在线考试系统商业项目

基于Java的在线考试系统(附:源码和课件)

求大学入学英语考试试卷(含答案)

考试资料|南京理工大学C++历年试卷及解析

如何获得在线考试系统的答案或是题库