php考试倒计时提交系统,基于Ajax技术实现考试倒计时并自动提交试卷

这篇文章主要介绍了基于Ajax技术实现考试倒计时并自动提交试卷 的相关资料,非常不错,具有参考和学习ajax的价值,对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中设置的,关键代码如下:

StartExam

com.lh.servlet.StartExam

examTime

20

(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页,用于输出计时开始时间。关键代码如下:

${showStartTime}

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

${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 ){

showStartTimep.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;

showRemainTimep.innerHTML=h;

h=h.replace(/\s/g,""); //去除字符串中的Unicode空白符

showRemainTimep.innerHTML=h;

if(h=="00:00:00"){

form1.submit();

}

}

}

}

(7)为了实现页面加载后自动计时,需要在开始考试页面的

标签中通过onload事件应用window.setInterval()方法调用showStartTime()函数和showRemailTime()函数,关键代码如下:

以上所述是小编给大家介绍的基于Ajax技术实现考试倒计时并自动提交试卷 的相关知识,希望对大家有所帮助!

相关推荐:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,这是一个关于 PHPAjax 技术的问题,我会尽力回答。首先,实现考试倒计时自动提交试卷需要以下几个步骤: 1. 在 PHP设置考试时间和结束时间,并将其传递到前页面。 2. 在前页面使用 Ajax 技术实现倒计时功能。 3. 当倒计时结束时,自动提交试卷PHP处理。 以下是一个简单的实现思路: 1. 在 PHP设置考试时间和结束时间 在 PHP,可以使用 `date()` 函数获取当前时间,并根据考试时间长度计算出考试结束时间。然后将考试结束时间传递到前页面。 ```php // 设置考试时间长度(单位:分钟) $exam_length = 60; // 计算考试结束时间 $end_time = date('Y-m-d H:i:s', strtotime("+{$exam_length} minutes")); // 将考试结束时间传递到前页面 echo "<input type='hidden' id='end_time' name='end_time' value='{$end_time}'>"; ``` 2. 使用 Ajax 技术实现倒计时功能 在前页面,可以使用 JavaScript 和 Ajax 技术实现倒计时功能。首先,获取 PHP传递的考试结束时间,然后使用 JavaScript 计算出当前时间与考试结束时间的时间差,并将其显示在页面上。 ```javascript // 获取考试结束时间 var end_time = new Date($('#end_time').val()); // 每秒更新倒计时 var timer = setInterval(function() { // 计算时间差 var diff = end_time - new Date(); // 如果时间差小于等于零,表示考试时间已到,自动提交试卷 if (diff <= 0) { clearInterval(timer); // 停止计时器 submit_exam(); // 自动提交试卷 } // 将时间差显示在页面上 var minutes = Math.floor(diff / 1000 / 60); var seconds = Math.floor(diff / 1000 % 60); $('#countdown').text(minutes + '分' + seconds + '秒'); }, 1000); ``` 3. 自动提交试卷PHP处理 当倒计时结束时,可以调用一个 JavaScript 函数自动提交试卷。在该函数中,使用 Ajax 技术PHP发送试卷数据,并处理返回结果。 ```javascript function submit_exam() { // 获取试卷数据 var exam_data = $('#exam_form').serialize(); // 向 PHP发送试卷数据 $.ajax({ type: 'POST', url: 'submit_exam.php', data: exam_data, success: function(response) { // 处理返回结果 alert(response); }, error: function() { // 处理错误 alert('提交试卷失败!请稍后重试。'); } }); } ``` 在 PHP,可以使用 `$_POST` 变量获取提交试卷数据,并进行处理。 ```php // 获取试卷数据 $exam_data = $_POST['exam_data']; // 处理试卷数据 // ... // 返回处理结果 echo '提交试卷成功!'; ``` 希望这个简单的实现思路对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值