,ASP.net   工具软件   办公软件   操作系统   网络安全   设计在线   程序开发   教程宝典   软件下载   软件论坛,ASP.net
您的位置:软件 > 开发者网络 > 微软开发专栏 > Visual Studio.net专栏 > ASP.net > 正文
利用ASP.NET构建网上考试系统
[文章信息]
作者:姚渝涛
时间:2005-04-26
出处:天极网
责任编辑:方舟
[文章导读]
本文以ASP.net(C#)+SQL server为例说明了开发网上考试系统的实现方法
advertisement
热点推荐
· VB实现SQL Server 2000存储过程调用
· Java解析网络数据流的三种特殊方法
· 多媒体教程:网页表单文本域类型
· 体验V5E地形编辑:整体控制
· 打造完美可随意安装的WinXP镜像
[正文]

上一页  1 2 3  下一页

  三、试题生成:

  1、防止考生刷新页面:

  由于加载试题页面时将从数据库中随机抽取试题,所以应防止考生刷新面页(刷新页面会重新生成新的试题)。方法是将表StuInfo中的LogYn字段默认值设为0,加载试题后设为1,交卷评分后设为2,加载试题页面时进行相应检查,以防止页面的刷新,代码如下(test.aspx):

private void Page_Load(object sender, System.EventArgs e)
{
 if(!IsPostBack)
 {
  ...
  QuestCmd.CommandText="select LogYn from StuInfo where ExamId= '"+ Session["Id"].ToString()+"'";
  QuestConn.Open();
  SqlDataReader QuestRd=QuestCmd.ExecuteReader();
  QuestRd.Read();
  if(QuestRd["LogYn"].ToString().Trim().Equals("1")||QuestRd["LogYn"].ToString().Trim().Equals("2"))
  //判断是否已加载试题或是否已评分
  {
   ...
   Response.Write("<script language=\"javascript\">"+"\n");
   Response.Write("alert(\"不能刷新!请与管理员联系,重新登录。\")"+"\n</script>");
   ...
  }
  else
  {
   ...
   QuestCmd.CommandText="update StuInfo set LogYn='1'"; //已成功加载试题
   QuestCmd.ExecuteReader();
   ...
  }
 }
 ...
}

  2、随机生成试题:

  网上考试系统的关键是试题的随机生成,即对于不同的计算机访问系统时将从题库中随机地抽取不同的试题。

  在此我们可使用SQL语句"select top n * from mc order by newid()"从题库中随机抽取n条记录,其中newid()生成 uniqueidentifier 值(若是ACCESS数据库则用"select top n * from mc order by rnd(id)",其中id为自动编号字段)。

  在test.aspx页面上放置一个Panel容器控件,以便动态生成绑定到试题的控件,并将从表mc中随机生成的试题答案写入表StuInfo表中的mca字段,代码如下(test.aspx):

private void Page_Load(object sender, System.EventArgs e)
{
 if(!IsPostBack)
 {
  ...
  QuestCmd.CommandText="select top 10 * from mc order by newid()";//以随机生成10道题为例
  QuestConn.Open();
  QuestRd=QuestCmd.ExecuteReader();
  while(QuestRd.Read())
  {
   Literal LitTxt=new Literal();
   Literal LitBl=new Literal();
   CheckBoxList ChkMc=new CheckBoxList();
   ChkMc.ID="ChkMc"+i.ToString();
   LitTxt.Text=i.ToString()+"、 "+Server.HtmlEncode(QuestRd["Question"].ToString())+"<BR><Blockquote>";
   LitBl.Text="</Blockquote>";
   ChkMc.Font.Size=11;
   for(int j=1;j<=4;j++)
   {
    ChkMc.Items.Add(Server.HtmlEncode(QuestRd["Choice"+j.ToString()].ToString()));
    ChkMc.Items[j-1].Value=j.ToString();
   }
   mcStr+=QuestRd["Answer"].ToString().Trim(); //mcStr是存储随机生成试题答案的字符串变量
   MyPanel.Controls.Add(LitTxt);
   MyPanel.Controls.Add(ChkMc);
   MyPanel.Controls.Add(LitBl);
   i++;
  }
  ...
  QuestCmd.CommandText="update StuInfo set Mca='"+mcStr+"' where ExamId= '" +Session["Id"].ToString()+"'";   //将随机生成试题答案写入数据表
  QuestConn.Open();
  QuestRd=QuestCmd.ExecuteReader();
  ...
 }
 ...
}


上一页  1 2 3  下一页

发表评论推荐给朋友我想参加相关培训打印我对此感兴趣订阅电子杂志
天极社区邀请您:写博客日记  上传相片   论坛聊天  订阅电子杂志  推荐网摘   免费图铃工具
笔名:   请您注意:

 遵守国家有关法律、法规,尊重网上道德,承担一切因您的行为而直接或间接引起的法律责任。

 天极网拥有管理笔名和留言的一切权利。
评论:
 
,ASP.net相关内容,ASP.net焦点新闻
  • ASP.NET程序员应用程序域须知
  • ASP.NET中使用MD5和SHA1算法加密
  • ASP.NET技巧:为Blog打造个性日历
  • ASP.NET中实现MSN通知消息功能
  • GridView根据值的变化改变行列样式
  • FVD刺激高清碟机加速商业化 抢占商机最重要
  • 3家搜索引擎集体诉讼8848 吕春维未敢出席
  • 杨元庆:没有准备不会获批的备用方案
  • 军队信息化诞生新领域 电子军务呼之欲出
  • 世界经济论坛公布信息化程度全球最新排名
  • 2004政务绩效评估:政府门户尚处于发展阶段
  • 甲骨文出资5.15亿美元 意图收购RetekInc
  • 技术并购:帮你突破传统增长的“天花板”
  • ,ASP.netAdvertisement