1.概述

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

2.技术要点

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

3.具体实现代码

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

  1. /**
  2. * 构建XMLHttpRequest对象并请求服务器
  3. * @param reqType:请求类型(GET或POST)
  4. * @param url:服务器地址
  5. * @param async:是否异步请求
  6. * @param resFun:响应的回调函数
  7. * @param parameter :请求参数
  8. * @return :XMLHttpRequest对象
  9. */
  10. function httpRequest(reqType,url,async,resFun,parameter){
  11. var request = null;
  12. if( window.XMLHttpRequest ){ //非IE浏览器,创建XMLHttpRequest对象
  13. request = new XMLHttpRequest();
  14. }else if( window.ActiveXObject ){ //IE浏览器,创建XMLHttpRequest对象
  15. var arrSignatures = ["Msxml2.XMLHTTP", "Microsoft.XMLHTTP", "Microsoft.XMLHTTP", "MSXML2.XMLHTTP.5.0", "MSXML2.XMLHTTP.4.0", "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP"];
  16. for( var i = 0; i < arrSignatures.length; i++ ){
  17. request = new ActiveXObject( arrSignatures[i] );
  18. if( request || typeof( request ) == "object" )
  19. break;
  20. }
  21. }
  22. if( request || typeof( request ) == "object" ){
  23. if(reqType.toLowerCase()=="post"){ //以POST方式提交
  24. request.open(reqType, url, true); //打开服务器连接
  25. //设置MIME类型
  26. request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  27. request.onreadystatechange = resFun; //设置处理响应的回调函数
  28. parameter = encodeURI(parameter); //将参数字符串进行编码
  29. request.send(parameter); //发送请求
  30. }
  31. else{ //以GET方式提交
  32. url = url+"?"+parameter;
  33. request.open(reqType, url, true); //打开服务器连接
  34. request.onreadystatechange = resFun; //响应回调函数
  35. request.send(null); //发送请求
  36. }
  37. }
  38. else{
  39. alert( "该浏览器不支持Ajax!" );
  40. }
  41. return request;
  42. }

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

  1. function showWindow(){ window.open('StartExam?action=startExam','','width=750,height=500,scrollbars=1');
  2. }

(2)新建名为StartExam的Servlet实现类,该类用创建考试的开始时间和剩余时间。在该类中,创建一个全局变量examTime,用于记录考试时间,该变量的值是在web.xml中设置的,关键代码如下:

  1. <servlet>
  2. <servlet-name>StartExam</servlet-name>
  3. <servlet-class>com.lh.servlet.StartExam</servlet-class>
  4. <init-param>
  5. <param-name>examTime</param-name>
  6. <param-value>20</param-value>
  7. </init-param>
  8. </servlet>

(3)在StartExam类中,编写用于将页面转发到开始考试页面的方法startExam()。关键代码如下:

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

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

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

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

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

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

  1. var request1= false;
  2. var request2 = false;
  3. //请求Servlet获得开始时间
  4. function showStartTime(){
  5. var url = "StartExam";
  6. //此处需要加&nocache="+new Date().getTime(),否则将出现时间不自动走动的情况
  7. var parameter="action=showStartTime&nocache="+new Date().getTime();
  8. request1 = httpRequest("post",url,true,callbackFunc,parameter);
  9. }
  10. //回调函数
  11. function callbackFunc(){
  12. if( request1.readyState==4 ){
  13. if( request1.status == 200 ){
  14. showStartTimediv.innerHTML=request1.responseText;
  15. }
  16. }
  17. }
  18. //请求Servlet获得剩余时间
  19. function showRemainTime(){
  20. var url = "StartExam";
  21. var parameter="action=showRemainTime&nocache="+new Date().getTime();
  22. request2 = httpRequest("post",url,true,callbackFunc_R,parameter);
  23. }
  24. //回调函数
  25. function callbackFunc_R(){
  26. if( request2.readyState==4 ){
  27. if( request2.status == 200 ){
  28. h=request2.responseText;
  29. showRemainTimediv.innerHTML=h;
  30. h=h.replace(/\s/g,""); //去除字符串中的Unicode空白符
  31. showRemainTimediv.innerHTML=h;
  32. if(h=="00:00:00"){
  33. form1.submit();
  34. }
  35. }
  36. }
  37. }

(7)为了实现页面加载后自动计时,需要在开始考试页面的 <body>标签中通过onload事件应用window.setInterval()方法调用showStartTime()函数和showRemailTime()函数,关键代码如下:

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

Ajax技术--考试计时并自动提交试卷的更多相关文章

  1. html form禁止表单回车自动提交(通常原因是为在ajax提交前、后进行js判断控制)

    @*onkeydown事件用于禁止回车自动提交form,这样就不经过js控制跳转*@ <form action="/Account/CheckPsw" method=&quo ...

  2. JS原生Ajax&Jquery的Ajax技术&Json

    1.介绍Ajax Ajax = 异步 JavaScript 和 XML Ajax是一种创建快速动态网页的技术 通过在后台与服务器进行少量数据交换,Ajax 可以使网页实现异步更新.这意味着可以不用整个 ...

  3. Ajax技术使用之ajax与模态框结合的妙用

    Ajax技术使用之ajax与模态框结合的妙用 要求: 使用ajax的方式提交数据:https://www.cnblogs.com/-wenli/p/10470063.html 使用模态框完成增加数据, ...

  4. 服务器文档下载zip格式 SQL Server SQL分页查询 C#过滤html标签 EF 延时加载与死锁 在JS方法中返回多个值的三种方法(转载) IEnumerable,ICollection,IList接口问题 不吹不擂,你想要的Python面试都在这里了【315+道题】 基于mvc三层架构和ajax技术实现最简单的文件上传 事件管理

    服务器文档下载zip格式   刚好这次项目中遇到了这个东西,就来弄一下,挺简单的,但是前台调用的时候弄错了,浪费了大半天的时间,本人也是菜鸟一枚.开始吧.(MVC的) @using Rattan.Co ...

  5. ajax技术实现登录判断用户名是否重复以及利用xml实现二级下拉框联动,还有从数据库中获得

    今天学了ajax技术,特地在此写下来作为复习. 一.什么是ajax? 客户端(特指PC浏览器)与服务器,可以在[不必刷新整个浏览器]的情况下,与服务器进行异步通讯的技术  即,AJAX是一个[局部刷新 ...

  6. ajax技术初识与应用

    一.ajax技术初识 AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术.Ajax不是一种新的编 ...

  7. Django---CSRF的装饰器,CSRF的流程,JSON数据格式,ajax技术(基于JQ实现)

    Django---CSRF的装饰器,CSRF的流程,JSON数据格式,ajax技术(基于JQ实现) 一丶CSRF相关的装饰器 from django.utils.decorators import m ...

  8. Json介绍与Ajax技术

    AJAX   AJAX准备知识:JSON 什么是 JSON ? JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation) JSON 是轻量级的文本数据 ...

  9. SpringMVC: Ajax技术

    SpringMVC:Ajax技术 简介 AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML). AJAX 是一种在无需重新加载整个网 ...

随机推荐

  1. 怎样删除在Github中创建的项目

    像我这种刚開始学习的人总会不可避免的创建了一些測试性的项目.随后自然就是要删除了.那么该怎样删除呢? 你此刻可能处于这个界面: 也可能处于这个界面: 假设是第一个界面直接点击右側的"Sett ...

  2. 新买一款打印机hp5525N

    11900 RMB 彩色.激光.彩打. 让法国的工艺工程师给改成法语的了.

  3. 更换Winform 皮肤(下)----完全GDI+绘制

    skin皮肤和DLL程序及文件:下载 链接:http://www.cnblogs.com/DebugLZQ/archive/2013/04/15/3021659.html

  4. 网页制作之html基础学习4-格式与布局

    1.position:fixed 锁定位置(相对于浏览器的位置),例如有些网站的右下角弹窗 例: <head> <title>123</title> <sty ...

  5. ZOJ 3492 模拟循环链表线性查找

    WA了好几次最后找到错因是因为数组开小了! = = string whose length never exceeds 20 所以至少要开到21 = = ,我却一直开20 ╮(╯▽╰)╭ AC代码: ...

  6. 01-IOSCore - NSString、NSFileManager、NSBundle、StringAndObjectConvert

    模型 1 将数据存储到硬盘,将硬盘上的数据在读回内存 2 文件存储: NSFileHandle 对文件的读写 NSData 二进制数据 NSString 表示文件路径 NSFileManager(对文 ...

  7. Gradle的简介与安装

    Gradle介绍 Gradle是一个基于JVM的构建工具,它提供了: 像Ant一样,通用灵活的构建工具 可以切换的,基于约定的构建框架 强大的多工程构建支持 基于Apache Ivy的强大的依赖管理 ...

  8. Python 获取时间戳

    Python 获取时间通过 time 模块 如下代码,是通过获取当前的时间,按照格式输出 Python默认获取当前的时间返回的都是时间的元组,下面是元组的,字符串时间的一个转换输出 # -*- cod ...

  9. Ultra Office Control 2.0

    http://www.ultrashareware.com/Ultra-Office-Control.htm

  10. 基于visual Studio2013解决C语言竞赛题之1036递归求值

          题目 解决代码及点评 /* 36.已知有如下递推公式 求该数列的前n项.不允许使用数组. */ float fp50036(int n,float x,float ...