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()">

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM