在线测试,如何保存前页测试答案?

emin_lee 2006-06-08 02:56:04
比如,做一个在线测试的网站,每页测试5道题,共50道题,需要测10页,如何保存上一页用户测试的结果,在用户测试完50道题后,统一提交计算成绩?

1、存数据库?
如果用户中途放弃答题怎么办?

2、放session?
在线人数很多时,会不会增加服务器负担?

谢谢:)

...全文
241 18 打赏 收藏 转发到动态 举报
写回复
用AI写文章
18 条回复
切换为时间正序
请发表友善的回复…
发表回复
emin_lee 2006-06-11
  • 打赏
  • 举报
回复
结帐了~

谢谢各位的答案。
emin_lee 2006-06-10
  • 打赏
  • 举报
回复
各位还有没有其他解决办法?
谢谢~
纯当讨论讨论~

回头结帐!
emin_lee 2006-06-10
  • 打赏
  • 举报
回复
to dreamover(梦醒了)
----------------------------------
hidden复杂?
java.util.Map results = request.getParameterMap();
for(Object key:results.keySet()){
out.println("<input type=\"hidden\" name=\""+key+"\" value=\""+results.get(key)+"\">");
}//里面有同名多选项的话,需要修改一下代码
-----------------------------------------------------------------------------
个人也比较倾向于这个方法,谢谢!
dreamover 2006-06-09
  • 打赏
  • 举报
回复
谢谢各位了!
另外有一个与在线测试相关的问题:
如何控制测试时间?
如果是通过javascript来控制的话,客户刷新怎么处理?
是否有更好的办法?

=======================================

这个可以用session+javascript处理

用session记录开始时间
session.setAttribute("begintime",new Date());

<script type="text/javascript">
leavetime=60*60*1000-<%=(new Date() - session.getAttribute("begintime"))%>;
//60是考试时间,然后减去考生已用的时间
//当然实际代码不能这么写,我只是表达一下大体意思

setTimeout("交卷函数()",leavetime);
//复杂点,还可以加上提醒功能
</script>
dreamover 2006-06-09
  • 打赏
  • 举报
回复
hidden复杂?
java.util.Map results = request.getParameterMap();
for(Object key:results.keySet()){
out.println("<input type=\"hidden\" name=\""+key+"\" value=\""+results.get(key)+"\">");
}//里面有同名多选项的话,需要修改一下代码

这不比每页操作数据库简单?而且不用担心在数据库中产生垃圾数据,还要清理
emin_lee 2006-06-09
  • 打赏
  • 举报
回复
谢谢各位了!
另外有一个与在线测试相关的问题:
如何控制测试时间?
如果是通过javascript来控制的话,客户刷新怎么处理?
是否有更好的办法?
bainian 2006-06-08
  • 打赏
  • 举报
回复
还是写如库好点
=========================
个人觉得不管在什么时候都能很容易的去做任何的操作!!
FinalKing 2006-06-08
  • 打赏
  • 举报
回复
dreamover(梦醒了) ( ) 信誉:100
<input type="hidden">
======================================
个人觉得可行 存下结果 !
emin_lee 2006-06-08
  • 打赏
  • 举报
回复
楼上,hidden是否过于复杂?
用hidden保存每一个页面的答案?
dreamover 2006-06-08
  • 打赏
  • 举报
回复
<input type="hidden">
kevinliuu 2006-06-08
  • 打赏
  • 举报
回复
都可以作为解决方案,看你自己怎么选了
emin_lee 2006-06-08
  • 打赏
  • 举报
回复
emin_lee 2006-06-08
  • 打赏
  • 举报
回复
首先谢谢二位。
一位朋友提议用数据库存储每页的试题答案,
然后写一个数据库的job,
定时去清理那些没有完成答卷或者session超时的用户的答卷

诸位以为如何?
干啥呢 2006-06-08
  • 打赏
  • 举报
回复
我也是个初学者,和你们学习一下,不过提个小意见,写cookie会不会比写session省资源呢
kevinliuu 2006-06-08
  • 打赏
  • 举报
回复
如果这样的话,那用session也无妨
emin_lee 2006-06-08
  • 打赏
  • 举报
回复
谢谢楼上~
如果出于真实业务考虑,实际测试过程中,不允许用户事先知道试题,
那么对于略知网页代码的用户而言,他就可以通过查看源文件的方法,看到所有的50道题。
这样的话
如何解决呢?
kevinliuu 2006-06-08
  • 打赏
  • 举报
回复
可以考虑将50道题放在一个页面中,一次显示5道,上下页实际上换帧不换页,这样,答案是存在页面的,即使放弃,也没有什么关系
通过页面性能测试概念+页面加载过程+页面性能指标+页面性能测试工具的学习,可以学到如下内容:①WEB网站页面性能的指标(白屏时间、首屏加载完成时间、FP、FCP、DCL、CLS、FPS等);②WEB网站页面性能测试策略;③WEB网站页面加载过程(前端基础语言:HTML+CSS+JavaScript,DOM、CSSOM、渲染树、布局、绘制);④WEB网站页面性能测试工具的实际操作和功能介绍(开发者工具:控制台、网络、性能、Lighthouse、FPS渲染统计等);⑤WEB网站页面性能测试报告编写。⑥WEB网站页面性能测试步骤和实际操作。课程内容:第一章:课程简介1、课程介绍2、课程大纲第二章:页面性能测试1、页面性能测试概念2、页面性能测试专业术语3、页面性能测试策略第三章:页面加载过程1、HTML概念,HTML5实例,HTML5文档2、CSS概念,CSS实例,CSS文档3、JavaScript概念,JavaScript脚本实例和作用4、DOM和CSSOM理解5、HTML5渲染引擎理解6、HTML5页面内容渲染的过程,HTML渲染树第四章:页面性能测试工具1、页面性能测试具体工具2、Chrome开发者工具介绍第五章:页面性能测试工具-控制台:window.performance1、控制台:window.performance介绍2、window.performance.timing执行结果加载字段理解3、window.performance.timing执行结果属性对应页面阶段理解4、window.performance页面性能参数计算5、window.performance页面性能关键指标计算第六章:页面性能测试工具-网络面板1、Chrome-开发者工具-网络面板介绍2、Chrome-开发者工具-网络-瀑布流指标第七章:页面性能测试工具-性能面板1、Chrome-开发者工具-性能面板-使用方法2、Chrome-开发者工具-性能面板介绍3、Chrome-开发者工具-性能面板-控制按钮区域4、Chrome-开发者工具-性能面板-Overview区域5、Chrome-开发者工具-性能面板-火焰图区域6、Chrome-开发者工具-性能面板-内存图区域7、Chrome-开发者工具-性能面板-统计汇总区域8、Chrome-开发者工具-性能面板-统计汇总区域-摘要内容9、Chrome-开发者工具-性能面板-统计汇总区域-事件时长、调用、发生顺序第八章:页面性能测试工具-FPS监控1、Chrome-开发者工具-FPS监控-FPS介绍、FPS视觉效果、FPS查看方法第九章:页面性能测试-Lighthouse面板1、Chrome-开发者工具-Lighthouse介绍、操作方法、运行的生命周期2、Chrome-开发者工具-Lighthouse报告指标分析3、Chrome-开发者工具-Lighthouse的报告优化建议第十章:页面性能测试工具-Performance insights面板1、Chrome-开发者工具-Performance insights操作方法2、Chrome-开发者工具-Performance insights分析报告第十一章:网速调研1、全国网速的调研和本机网速测试第十二章:页面性能测试总结1、页面性能测试指标采集方式2、页面性能测试报告3、页面性能测试-操作步骤​

81,094

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧