【C#+JavaScript+SQL Server】实现Web端在线考试系统 五:考试模块设计(附源码和资源)

news2025/1/19 14:33:50

需要源码请点赞关注收藏后评论区留言私信~~~

一、考试模块概述

在线考试系统中的考试模块主要包括阅读考试规则,选择考试科目,随机抽取试题,答题计时器以及自动交卷并评分等功能

在开发考试系统过程中,需要考虑的一点是如何将试题显示在页面上,如何将试题从数据库中读取出来,比较合理的做法是将所有试题信息存储在数据库中,然后随机抽取若干试题,动态的显示在页面中

在线考试系统和普通考试的流程是一样的,考生答卷完毕后要对考生的答案评分,根据实际的需要,在线考试系统加入了自动评分模块,当考生答题完毕提交试卷后,系统会根据考生选择的答案与正确答案进行比较,最后进行评分

 二、选择考试科目

在随机抽取试题之前,考生要选择考试的科目,然后根据选择的科目随机从数据库中抽取试题给考生

程序首先根据考生选择的科目对数据库进行检索,查看数据库中是否有相关的试题,如果存在试题则随机抽取试题,否则提示考生选择的考试科目在数据库中没有试题,开始考试按钮的Click事件代码如下

protected void Button2_Click(object sender, EventArgs e)
{
    string StuID = Session["ID"].ToString();				//考生的编号
    string StuKC = ddlKm.SelectedItem.Text;				//选择的考试科目
    SqlConnection conn = BaseClass.DBCon();				//连接数据库
    conn.Open();											//打开连接
    SqlCommand cmd = new SqlCommand("select count(*) from tb_score where StudentID='" + StuID 
+ "' and LessonName='" + StuKC + "'", conn);				//执行SQL语句
    int i = Convert.ToInt32(cmd.ExecuteScalar());			//获取返回值
    if (i > 0)											//如果返回值大于0
    {
        MessageBox.Show("你已经参加过此科目的考试了");
    }
    else
    {
        cmd = new SqlCommand("select count(*) from tb_test where testCourse='" + StuKC + "'", 
conn);
        int N = Convert.ToInt32(cmd.ExecuteScalar());		//获取返回值
        if (N > 0)										//如果返回值大于0
        {
            //执行SQL语句
            cmd = new SqlCommand("insert into tb_score(StudentID,LessonName,StudentName) 
values('" + StuID + "','" + StuKC + "','" + lblName.Text + "')", conn);                             
           cmd.ExecuteNonQuery();
           conn.Close();									//关闭连接
           Session["KM"] = StuKC;
Response.Write("<script>window.open('StartExam.aspx','newwindow','status=1,scrollbars=1,re
sizable=1')</script>");
            Response.Write("<script>window.opener=null;window.close();</script>");
        }
        else
        {
            MessageBox.Show("此科目没有考试题");				//弹出提示信息
            return;
        }
    }
}

 三、设计考试页面

新建一个网页作为考试页面,它的主要控件如下

四、随机抽取试题

 当开始考试页面加载时,根据考生选择的科目在数据库中随机抽取试题,并显示在Panel控件中

public string Ans = null;								//建立存储正确答案的公共变量
public int tNUM;										//记录考题数量
protected void Page_Load(object sender, EventArgs e)
{
    lblEndtime.Text = "考试时间为10分钟,每小题5分,考试已用时:";			//显示考试提示
    lblStuNum.Text = Session["ID"].ToString();							//显示考生编号
    lblStuName.Text = Session["name"].ToString();						//显示考生姓名
    lblStuSex.Text = Session["sex"].ToString();							//显示考生性别
    lblStuKM.Text = "[" + Session["KM"].ToString() + "]" + "考试试题";	//显示考试科目
    int i = 1;														//初始化变量
    SqlConnection conn = BaseClass.DBCon();							//连接数据库
    conn.Open();														//打开连接
    SqlCommand cmd = new SqlCommand("select top 10 * from tb_test where testCourse='" + 
Session["KM"].ToString() + "' order by newid()", conn);
    SqlDataReader sdr = cmd.ExecuteReader();			//创建记录集
    while (sdr.Read())
    {
        Literal littxt = new Literal();				//创建Literal控件
        Literal litti = new Literal();					//创建Literal控件
        RadioButtonList cbk = new RadioButtonList();	//创建RadioButtonList控件
        cbk.ID = "cbk" + i.ToString();
        littxt.Text = i.ToString() + "、" + Server.HtmlEncode(sdr["testContent"].ToString()) 
+ "<br>ckquote>";
        litti.Text = "</Blockquote>";
        cbk.Items.Add("A. " + Server.HtmlEncode(sdr["testAns1"].ToString()));	//添加选项A
        cbk.Items.Add("B. " + Server.HtmlEncode(sdr["testAns2"].ToString()));	//添加选项B
        cbk.Items.Add("C. " + Server.HtmlEncode(sdr["testAns3"].ToString()));	//添加选项C
        cbk.Items.Add("D. " + Server.HtmlEncode(sdr["testAns4"].ToString()));	//添加选项D
        cbk.Font.Size = 11;							//设置文字大小
        for (int j = 1; j <= 4; j++)
        {
            cbk.Items[j - 1].Value = j.ToString();
        }
        Ans += sdr[6].ToString();						//获取试题的正确答案
        if (Session["a"] == null)						//判断是否第一次加载
        {
            //如果第一次加载则将正确答案赋值给Session["Ans"]
            Session["Ans"] = Ans;
        }
        Panel1.Controls.Add(littxt);					//将控件添加到Panel中
        Panel1.Controls.Add(cbk);						//将控件添加到Panel中
        Panel1.Controls.Add(litti);					//将控件添加到Panel中
        i++;											//使i递增
        tNUM++;										//使tNUM递增
    }
    sdr.Close();
    conn.Close();										//关闭连接
    Session["a"] = 1;
}

五、计时器功能的实现

在考试页面中具有考试计时的功能,该功能是通过JavaScript脚本实现的

<script language="javascript">
    var sec = 0;
    var min = 0;
    var hou = 0;
    flag = 0;
    idt = window.setTimeout("countDown();", 1000);
    function countDown() {
        sec++;
        if (sec == 60) { sec = 0; min += 1; }
        if (min == 60) { min = 0; hou += 1; }
        document.getElementById("lbltime").innerText = min + "分 " + sec + " 秒";
        idt = window.setTimeout("countDown();", 1000);
        if (min == 10) {
            document.getElementById("btnsubmit").click();
        }
    }
</script>

六、交卷功能的实现

考生在规定的时间内进行考试,当考生答题完毕后,单击交卷功能,提交试卷,此时系统会将该考生的答题结果提交给自动评分模块,交卷按钮的Click事件代码如下

protected void btnsubmit_Click(object sender, EventArgs e)
{
    string msc = "";									//建立变量msc存储考生答案
    for (int i = 1; i <= 10; i++)
    {
        RadioButtonList list = (RadioButtonList)Panel1.FindControl("cbk" + i.ToString());
        if (list != null)
        {
            if (list.SelectedValue.ToString() != "")
                msc += list.SelectedValue.ToString();	//存储考生答案
            else
                msc += "0";							//如果没有选择则为0
        }
    }
    Session["Sans"] = msc;							//考生答案
    string sql = "update tb_score set RigthAns='" + Ans + "',StudentAns='" + msc + "' where 
StudentID='" + lblStuNum.Text + "'";					//更新考试结果数据表
    BaseClass.OperateData(sql);
    Response.Redirect("result.aspx?BInt=" + tNUM.ToString());
}

七、自动评分功能的实现

考生将试题提交到自动评分模块,该模块对考生答案进行评分,并将考生的成绩添加到数据表中

protected void Page_Load(object sender, EventArgs e)
{
    string Rans = Session["Ans"].ToString();					//获取正确答案
    int j = Convert.ToInt32(Request.QueryString["BInt"]);		//获取试题数量
    string Sans = Session["Sans"].ToString();					//获取考生答案
    int StuScore = 0;											//将考试成绩初始化为0
    for (int i = 0; i < j; i++)
    {
        if (Rans.Substring(i, 1).Equals(Sans.Substring(i, 1)))	//将考生答案与正确答案作比较
        {
            StuScore += 5;										//如果答案正确加5分
        }
    }
    this.lblResult.Text = StuScore.ToString();					//显示考试成绩
    this.lblkm.Text = Session["KM"].ToString();					//显示考试科目
    this.lblnum.Text = Session["ID"].ToString();				//显示考生编号
    this.lblname.Text = Session["name"].ToString();				//显示考生姓名
    //更新考试结果数据表
    string strsql = "update tb_score set score='" + StuScore.ToString() + "' where StudentID='" 
+ Session["ID"].ToString() + "' and LessonName='" + Session["KM"].ToString() + "'";
    BaseClass.OperateData(strsql);
}

创作不易  觉得有帮助请点赞关注收藏~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/408957.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

前端工程化详解——理解与实践前端工程化

前言&#xff1a; 前端工程化一直是一个老生常谈的问题&#xff0c;不管是面试还是我们在公司做基建都会经常提到前端工程化&#xff0c;那么为什么经常会说到前端工程化&#xff0c;并没有听过后端工程化、Java工程化或者Python工程化呢&#xff1f;我们理解的前端工程化是不是…

uniappvideo避坑指南(H5、小程序、app)

今天写下这篇文章已是蓄谋已久了&#xff0c;背景是年初接到项目需求开发基于H5运行的视频学习平台&#xff0c;以及后来uniapp转小程序app开发。相信开发过uniapp的video应该或多或少都遇到过一些坑&#xff0c;开场就不多说了&#xff0c;直接上干货。 项目要求用户不得拖动…

vue3引入router

1.添加vue-router依赖 进入项目路径的cmd下&#xff0c;执行命令 npm install vue-router4 或者yarn add vue-router4 推荐使用yarn命令&#xff0c;比npm安装更快 2.执行npm install重新加载依赖 3.在src文件夹下创建一个router文件夹 4.在router文件夹下创建index.js文件&…

JavaScript核心技术之JSON详解

JSON是什么&#xff1f; JSON&#xff08;JavaScript Object Notation, JS对象简谱&#xff09;是一种轻量级的数据交换格式。它基于 ECMAScript&#xff08;European Computer Manufacturers Association, 欧洲计算机协会制定的js规范&#xff09;的一个子集&#xff0c;采用…

undetected_chromedriver的使用

undetected_chromedriver是专门针对浏览器识别做出来的拓展 直接使用undetected_chromedriver第三方库 if __name__ __main__:from selenium import webdriverfrom selenium.webdriver.common.by import Byfrom selenium.webdriver.support.ui import WebDriverWaitfrom sel…

前端数据加密的几种方式

1.base64加密方式 1.1 base64是什么&#xff1f; Base64&#xff0c;顾名思义&#xff0c;就是包括小写字母a-z、大写字母A-Z、数字0-9、符号""、"/"一共64个字符的字符集&#xff0c;&#xff08;另加一个“”&#xff0c;实际是65个字符&#xff0c;至…

Access-Control-Allow-Origin跨域解决及详细介绍

首先&#xff0c;跨域不是问题。是一种安全机制。 这是你在开发时、上线前就必须提前考虑到的安全问题并且采取合适的手段去避免这个问题带来的程序错误。不过通常情况下&#xff0c;前端开发的小伙伴们都非常坚信后端小伙伴的接口一定已经处理好了跨域这个需求。然而事实上许多…

JavaWeb 项目 --- 表白墙 和 在线相册

文章目录一. 案例: 表白墙 (使用模板引擎)1. 首先创建 maven 项目2. 创建好模板文件3. 使用数据库存储数据.创建一个类用于数据库连接4. 使用 监视器 来初始化 Thymeleaf5. 编写 Servlet 代码① 重写 doGet 方法② 重写 doPost 方法③ 实现 load 方法④ 实现 save 方法6. 注意事…

Vue中key的作用及原理

1. 先说结论 key在Vue是DOM对象的标识&#xff1b;进行列表展示时&#xff0c;默认key是index&#xff1b;如果数据只做展示使用&#xff0c;使用index作为key是没有任何问题的&#xff1b;如果使用index作为key&#xff0c;而后续操作会破坏顺序&#xff0c;一定会带来效率问…

vue3 antd table表格样式修改——使用rowClassName更改某行数据的样式

vue3 antd项目实战——修改ant design vue组件中table表格的默认样式&#xff08;二&#xff09;知识调用场景复现修改table表格的行样式一、rowClassName添加行样式二、表格的不可控操作写在最后知识调用 文章中可能会用到的知识链接vue3ant design vuets实战【ant-design-vu…

解决:在 VSCode 中如何设置默认的浏览器为Chrome或Firefox

1、问题描述&#xff1a; 在 VSCode 编辑器中&#xff0c;其一般默认打开的浏览器是 IE 浏览器&#xff0c;而我已经习惯使用 Chrome 浏览器&#xff0c;以及会遇到页面的调试等不同的问题&#xff0c;因此需要将 VSCode 的默认浏览器调整为 Chrome 浏览器&#xff1b; 2、操…

【web前端开发】超详细讲解CSS盒子模型

文章目录1.盒子模型介绍2.内容3.边框4.内边距5.⭐盒子大小计算6.⭐内减模式7.外边距外边距的合并外边距的塌陷行内元素的垂直外边距8.⭐清除默认样式9.⭐版心居中1.盒子模型介绍 所有HTML元素可以看作盒子,CSS盒模型本质上是一个盒子&#xff0c;封装周围的HTML元素&#xff0c…

使用Vue来完成项目中的首页导航+左侧菜单

目录 1. 准备工作 2. 动态树 2.1 在配置请求路径 2.2 使用动态数据构建导航菜单 2.2.1 通过接口获取数据 2.2.3 通过后台获取的数据构建菜单导航 2.3 点击菜单实现路由跳转 2.3.1 创建书本管理组件 2.3.2 配置路由 2.3.3 修改LeftAside组件 2.3.4 修改Main组件 3. …

8个不能错过的程序员必备网站,惊艳到我了!!!

程序员是一个需要不断学习的职业&#xff0c;不少朋友每天来逛CSDN、掘金等网站&#xff0c;但一直都抱着“收藏从未停止&#xff0c;学习从未开始”的态度&#xff0c;别骗自己了兄弟。在编程体系中&#xff0c;有很多不错的小工具&#xff0c;可以极大得提升我们的开发效率。…

前端技术:解决执行npm install提示 xxx packages are looking for funding run `npm fund` for details的问题 详述npm fund

目录复现问题分析问题npm fund的命令npm fund的由来npm fund与npm ls解决问题参看文献&#x1f610; 我的博客&#xff0c;不仅帮你解决此类问题&#xff0c;还会告诉如何去分析定位问题。 复现问题 今天执行如下命令时&#xff1a; npm install报出如下问题&#xff1a; 2…

cookie、localStorage和sessionStorage详解

目录 一、cookie 二、Web storage 1、localStorage 2、sessionStorage的使用 3、复杂数据类型储存 Web Storage带来的好处&#xff1a; 三、sessionStorage、localStorage和cookie的区别 一、cookie cookie是客户端与服务器端进行会话使用的一个能够在浏览器本地化存储…

vue引入elementUi后打开页面报错Uncaught TypeError: Cannot read properties of undefined(reading ‘prototype‘)

vue引入elementUi后打开页面报错 本人在用idea创建vue项目并引入elemenUi之后网页报错&#xff1a; Uncaught TypeError: Cannot read properties of undefined(reading ‘prototype’)。 百度了很多办法都说是因为在vue3中引入了elementUi&#xff0c;vue3.0之后是不支持el…

基于Java+Springmvc+vue+element员工信息管理系统详细设计

博主介绍&#xff1a;✌公司项目主程、全网粉丝10W,csdn特邀作者、博客专家、CSDN新星计划导师、java领域优质创作者,CSDN博客之星TOP100、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和毕业设计✌ &#x1f345;文末获取源码联系&#x1f345; &#x1f345;…

React中实现插槽效果的方案

文章目录React实现插槽children实现插槽props实现插槽React实现插槽 在开发中&#xff0c;我们抽取了一个组件&#xff0c;但是为了让这个组件具备更强的通用性&#xff0c;我们不能将组件中的内容限制为固定的div、span等等这些元素。 我们应该让使用者可以决定某一块区域到…

项目部署,一点也不难!

目录 一、部署前准备 &#xff08;一&#xff09;前端多环境准备 &#xff08;二&#xff09;后端多环境准备 二、项目部署 &#xff08;一&#xff09;原始部署 1、前端部署 2、前端部署测试 3、后端部署 &#xff08;二&#xff09;宝塔 Linux 部署 1、前端部署 2…