ASP.NET基于BS的计算机等级考试系统的设计与实现

摘    要

随着计算机技术的发展及计算机的日益普及,基于B/S结构的考试系统与无纸化办公一样已成为大势所趋。论文详细论述了一个基于B/S结构的计算机等级考试系统的设计过程。软件采用ASP.NET 2005作开发平台,C#作编程语言,SQL Server 2005作数据库管理系统,实现了试题管理、试卷生成、在线考试、试卷评判、权限管理、在线报名及站内公告等功能。系统符合全国计算机等级考试的要求。

首先阐述了该系统的开发背景、意义;其次介绍了相关的开发工具及技术基础;接着对系统的需求进行了分析,并提出了具体的设计方案和数据库模型;然后展现了整个系统的具体实现,包括数据库的设计和连接,各功能模块的实现;最后对该软件进行了严格的测试。

关键词: B/S结构;计算机等级考试;考试系统

2.1 B/S结构

B/S(Browser/Server)结构即浏览器和服务器结构。它是随着Internet技术的兴起,对C/S结构的一种变化或者改进的结构。在这种结构下,用户工作界面是通过WWW浏览器来实现,极少部分事务逻辑在前端(Browser)实现,但是主要事务逻辑在服务器端(Server)实现,形成所谓三层3-tier结构。这样就大大简化了客户端电脑载荷,减轻了系统维护与升级的成本和工作量,降低了用户的总体成本(TCO)。

2.2 开发工具简介

2.2.1 Visual C# 2005简介

Microsoft Visual C# 2005(读作 C sharp)是一种编程语言,它是为生成在 .NET Framework 上运行的多种应用程序而设计的。C# 简单、功能强大、类型安全,而且是面向对象的。C# 凭借它的许多创新,在保持 C 样式语言的表示形式和优美的同时,实现了应用程序的快速开发。

2.2.2 SQL Sever 2005简介

SQL Server 是一个全面的、集成的、端到端的数据解决方案,它为企业中的用户提供了一个安全、可靠和高效的平台用于企业数据管理和商业智能应用。SQL Server 2005 为IT专家和信息工作者带来了强大的、熟悉的工具,同时减少了在从移动设备到企业数据系统的多平台上创建、部署、管理及使用企业数据和分析应用程序的复杂度。 通过全面的功能集、和现有系统的集成性、以及对日常任务的自动化管理能力,SQL Server 2005 为不同规模的企业提供了一个完整的数据解决方案。SQL Server 数据平台包括如下工具:关系型数据库、复制服务、通知服务、集成服务、分析服务、报表服务、管理工具、开发工具。 SQL Server 2005 数据平台为不同规模的组织提供了如下好处:充分利用数据资产、提高生产力、减少IT复杂度、更低的总体拥有成本 (TCO)。

4.2 系统功能结构图

根据需求分析,在线考试系统的结构图如下:

图2 系统功能结构图

4.3 系统架构

本系统采用ASP.NET应用程序典型的三层架构模式,其结构如图所示

各层功能介绍:

数据访问层:系统最低层,提供数据库操作的接口和存储本系统所有数据;

业务逻辑层:处于页面示层与数据访问层之间,与数据库直接关联,同时又为页面示层服务。实现业务的具体逻辑,如考生报名、登录参考、试卷试题管理等;

页面示层:系统最外层,将业务功能在浏览器上显示出来,用户通过界面对系统进行操作。

5.1  用户登录模块设计

5.1.1前台页面设计

管理员/阅卷人输入账号及密码,系统查询数据库,自动配对用户类型,进入相应的管理页面。如果出现错误,系统会弹出相应的提示信息。

5.1.2后台功能代码

单击登录按钮事件:

    protected void btnOK_Click(object sender, EventArgs e)

    {

        string UserName = txtName.Text;

        string UserPwd = Security.Encrypt(txtPwd.Text);

        User user = new User();

        user.LoadNameData(UserName);

        if (user.Exist) //如果用户存在

        {

            if (user.UserPwd == UserPwd)  //如果密码,转入留言列表页面

            {

                Session.Add("UserID", user.UserID);

                Session.Add("UserIDCard", user.UserIDCard);

                Session.Add("UserName", user.UserName);

                if (user.UserType == 3)

                {

                    Session["IsAdmin"] = "Admin";

                    Response.Redirect("Admin/AdminInfo.aspx");

                }

                else

                {

                    Session["IsAdmin"] = "Teacher";

                    Response.Redirect("Teacher/Default.aspx");

                }

            }

            else                 //如果密码错误,给出提示,光标停留在密码框中

            {

                Response.Write("<Script Language=JavaScript>alert(\"密码错误,请重新输入密码!\")</Script>");

                txtPwd.Focus();

            }

        }

        else                        //如果用户不存在

        {

            Response.Write("<Script Language=JavaScript>alert(\"对不起,用户不存在!\")</Script>");

        }

    }

5.2  后台管理页面设计

管理页面只允许具有管理员权限的人员访问,因此在每个管理页面都有相关的权限判断,以保证系统的安全使用。

if (Session["IsAdmin"] == null)

{

    Response.Write("<Script Language=JavaScript>alert('管理员未登录,非法请求!');</Script>");

    Response.Write("<Script Language=JavaScript>window.location.href='../AdminLogin.aspx';</Script>");

}

5.2.1人员管理页面设计

图6 人员管理

此页面用于管理所有用户,包括考生、阅卷人和管理员。通过用户类型下拉框选择相应类型的用户,在GridView中会显示出用户详细的信息。当考生报名成功后,前来交费时,管理员可以通过审核方式来确认考生的参考资格。管理员也可以删除一些无效用户。

审核事件代码:

  foreach (string UserID in selectedUsers)

  {

      Hashtable ht = new Hashtable();

      ht.Add("IsCheck", 1);

      (new User()).Check(ht, UserID);

   }

   Response.Write("<Script Language=JavaScript>alert('审核考生成功!');</Script>");

    Query();

删除事件代码:

  foreach (string UserID in selectedUsers)

  {

      User.Delete(UserID);

  }

  Query();

5.2.2试题管理页面设计

图7 试题管理

此页面用于管理所有试题信息。通过考试科目下拉框选择相应的科目,在GridView中会显示出试题的详细信息,包括题干、备选答案和正确答案。管理员可以对试题进行编辑、删除操作。

操作实现代码:

    protected void gvQuestion_RowCommand(object sender, GridViewCommandEventArgs e)

    {

        int index = Convert.ToInt32(e.CommandArgument); //待处理的行下标

        int questionId = -1;

        switch (e.CommandName)

        {

            //修改

            case "Edit":

                questionId = Convert.ToInt32(gvQuestion.Rows[index].Cells[0].Text);

                Response.Redirect("QuestionAddEdit.aspx?id=" + questionId);

                break;

            //删除

            case "Delete":

                questionId = Convert.ToInt32(gvQuestion.Rows[index].Cells[0].Text);

                Question question = new Question();

                question.GetSingleQuestion(questionId);

                question.Delete();

                Response.Write("<Script Language=JavaScript>alert('删除成功!');</Script>");

                gvBind();

                break;

            default:

                break;

        }

    }

5.2.3公告管理页面设计

此页面用于管理网站公告信息。通过GridView显示出公告的详细信息,包括编号、标题和时间。管理员可以通过详细信息查看公告内容,也可以对公告进行编辑、删除操作。

GridView数据绑定:

    private void InitData()

    {

        News news = new News();

        DataSet ds = news.GetNews();

        gvNewsList.DataSource = ds;

        gvNewsList.DataBind();

    }

操作代码:

    protected void gvNewsList_RowCommand(object sender, GridViewCommandEventArgs e)

    {

        int index = Convert.ToInt32(e.CommandArgument); //待处理的行下标

        int newsId = -1;

        switch (e.CommandName)

        {

            //修改

            case "Edit":

                newsId = Convert.ToInt32(gvNewsList.Rows[index].Cells[0].Text);

                Response.Redirect("NewsAddEdit.aspx?id=" + newsId);

                break;

            //删除

            case "Delete":

                newsId = Convert.ToInt32(gvNewsList.Rows[index].Cells[0].Text);

                News news = new News();

                news.GetSingleNews(newsId);

                news.Delete();

                Response.Write("<Script Language=JavaScript>alert('删除成功!');</Script>");

                InitData();

                break;

            default:

                break;

        }

    }

5.2.4密码管理页面设计

此页面用于管理员信息修改。当管理员名及原密码均正确时,可以对管理员的相关信息进行修改操作。否则将无法修改相关信息。

修改事件代码:

    if ( UserOldPwd == user.UserPwd )

    {

        Hashtable ht = new Hashtable();

        ht.Add("UserPwd", SqlStringConstructor.GetQuotedString(UserPwd));

        ht.Add("UserIDCard", SqlStringConstructor.GetQuotedString(txtIDCard.Text));

        user.Update(ht);

        Response.Write("<Script Language=JavaScript>alert(\"更新数据成功,请重新登录!\")</Script>");

        Session.Abandon();

        Response.Write("<Script Language=JavaScript>window.location.href='../AdminLogin.aspx';</Script>");

    }

    else

    {

        Response.Write("<Script Language=JavaScript>alert(\"原密码错误!\")</Script>");

    }

5.2.5试卷成绩信息管理页面设计

此页面用于管理考生考试信息。在GridView中显示出了所有考生的考试信息,包括考试科目、总成绩和是否通过阅卷人审核。阅卷人可以查看考试的详细信息,并进行进一步地操作,如图11所示。

单击审核事件:

  foreach ( string ID in selectedIDs )

  {

      Hashtable ht = new Hashtable();

      ht.Add("IsCheck", 1);

      (new Score()).Check(ht, ID);

  }

  Response.Write("<Script Language=JavaScript>alert('审核试卷成功!');</Script>");

  Query();

此页面用于显示考试的详细信息。阅卷人可以查看到考生考试的具体信息,包括考试时间、成绩以及每一道题的答案。阅卷人可以根据考生的答题情况,对考生分数进行相应的修改。

单击修正事件:

    protected void btnModify_Click(object sender, EventArgs e)

    {

        if (txtModifyScore.Text != "")

        {

            Score score = new Score();

            score.ID = Convert.ToInt32(Request.QueryString["id"]);

            Hashtable ht = new Hashtable();

            ht.Add("TotalScore", SqlStringConstructor.GetQuotedString(txtModifyScore.Text));

            ht.Add("IsCheck", 1);

            score.Update(ht);

            Response.Write("<Script Language=JavaScript>试卷得分修改成功!</Script>");

        }

        else

        {

            Response.Write("<Script Language=JavaScript>alert('请输入实际得分!');</Script>");

        }

    }

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

比较指令CMP

cmp 比较 将2个值比较输出给软元件 大于条件软元件得电 等于软元件1得电 小于软元件2得电 1&#xff0c;当计数起接通一次Y2得电 当计数器等于5时Y1 得电 当计数器大于5时Y0得电

python中time库的time.time()函数的作用是什么?

python中time库的time.time()函数的作用是什么&#xff1f; 作用&#xff1a;Python time time() 返回当前时间的时间戳&#xff08;1970纪元后经过的浮点秒数&#xff09;。 time()方法语法&#xff1a;time.time() #!/usr/bin/python # Write Python 3 code in this onlin…

蓝桥杯——18

学习视频&#xff1a;21-广度优先搜索练习_哔哩哔哩_bilibili Q&#xff1a;密码锁 #include<iostream> #include<queue> using namespace std; int s, e; bool vis[10000]; struct node {int state;int step;node(int s1, int s2) {state s1;step s2;} }; int…

《经典论文阅读2》基于随机游走的节点表示学习—Deepwalk算法

word2vec使用语言天生具备序列这一特性训练得到词语的向量表示。而在图结构上&#xff0c;则存在无法序列的难题&#xff0c;因为图结构它不具备序列特性&#xff0c;就无法得到图节点的表示。deepwalk 的作者提出&#xff1a;可以使用在图上随机游走的方式得到一串序列&#x…

Java 设计模式系列:模板方法模式

简介 模板方法模式是一种行为型设计模式&#xff0c;它定义一个操作中的算法骨架&#xff0c;将一些步骤推迟到子类中。模板方法模式使得子类可以不改变一个算法的结构&#xff0c;即可重定义该算法的某些特定步骤。 在模板方法模式中&#xff0c;抽象类中定义了一系列基本操…

网络篇10 | 网络层 IP

网络篇10 | 网络层 IP 01 简介02 名称解释03 IP报文格式(IPv4)1&#xff09;4位版本协议(version)2&#xff09;4位首部长度(header length)3&#xff09;8位服务类型(Type Of Service, TOS)4&#xff09;16位总长度5&#xff09;16位(分片)标识6&#xff09;3位(分片)标志7&am…

深度学习学习日记4.14 数据增强 Unet网络部分

数据增强 transforms.Compose([&#xff1a;这表示创建一个转换组合&#xff0c;将多个数据转换操作串联在一起 transforms.RandomHorizontalFlip()&#xff1a;这个操作是随机水平翻转图像&#xff0c;以增加数据的多样性。它以一定的概率随机地水平翻转输入的图像。 transfo…

coreldraw2024直装版下载 永久免费使用附下载安装教程( 仅限 win10用户 )

CorelDRAW 2024具有一些特别的优势&#xff0c;这些优势不仅体现在其丰富的功能和卓越的性能上&#xff0c;还体现在其跨平台的兼容性上。 首先&#xff0c;CorelDRAW 2024支持多种操作系统平台&#xff0c;包括但不限于Windows 10和Windows 11等高级操作系统。这意味着无论是…

webpack-(plugin,本地服务器,路径别名,安装vue)

安装vue npm i vue-loader -D npm i vue 编写一个vue文件&#xff1a; 在index.html中设置 一个id为app的div 将vue文件挂载到app中 vue比较特殊&#xff0c;除了使用loader外&#xff0c;还使用了plugin const path require("path"); const { VueLoaderPlugin …

zabbix 使用 dataease 做数据大屏

1、环境介绍 操作系统&#xff1a;龙蜥os 7.9 软件&#xff1a;dataease v1.18.18 zabbix&#xff1a; 6.0 2、软件下载 https://community.fit2cloud.com/#/products/dataease/downloads 3、将软件包上传到服务器并解压缩 tar -xvf dataease-v1.18.18-offline.tar.gz4、修改…

鸿蒙端云一体化开发--开发云函数--适合小白体制

开发云函数 那什么是云函数&#xff1f;我们将来又怎么去使用这个云函数呢&#xff1f; 答&#xff1a;我们之前要编写一些服务端的业务逻辑代码&#xff0c;那现在&#xff0c;在这种端云一体化的开发模式下&#xff0c;我们是把服务端的业务逻辑代码&#xff0c;通过云函数来…

Mybatis中SqlSession接口中的selectList方法

1、SqlSession SqlSession是Mybatis持久层框架提供的接口&#xff0c;该接口中包含了大量的CRUD操作方法&#xff08;既增删改查方法&#xff09;。 2、selectList方法 selectList方法是用于查询的方法&#xff0c;该方法具有多态性&#xff0c;如图所示&#xff08;打开myb…

qemu源码解析一

基于qemu9.0.0 简介 QEMU是一个开源的虚拟化软件&#xff0c;它能够模拟各种硬件设备&#xff0c;支持多种虚拟化技术&#xff0c;如TCG、Xen、KVM等 TCG 是 QEMU 中的一个组件&#xff0c;它可以将高级语言编写的代码&#xff08;例如 C 代码&#xff09;转换为可在虚拟机中…

51单片机-独立按键模块

1. 独立按键控制LED状态 轻触按键实现原理&#xff1a;按下时&#xff0c;接通&#xff0c;通过金属弹片受力弹动来实现接通和断开。 松开按键 按下之后&#xff1a;就会被连接 同时按下K1和K2时&#xff0c;P2_0,接口所连LED灯才亮。 #include <REGX52.H> void ma…

python-numpy(3)-线性代数

一、方程求解 参考资料 对于Ax b 这种方程&#xff1a; np.linalg.inv(A).dot(B)np.linalg.solve(A,b) 1.1 求解多元一次方程一个直观的例子 # AXB # X A^(-1)*B A np.array([[7, 3, 0, 1], [0, 1, 0, -1], [1, 0, 6, -3], [1, 1, -1, -1]]) B np.array([8, 6, -3, 1]…

Vue - 6( 13000 字 Vue3 入门级教程)

一 &#xff1a;Vue3 1.1 Vue3简介 2020年9月18日&#xff0c;Vue.js发布3.0版本&#xff0c;代号&#xff1a;One Piece&#xff08;海贼王&#xff09;耗时2年多、2600次提交、30个RFC、600次PR、99位贡献者github上的tags地址&#xff1a;https://github.com/vuejs/vue-ne…

Android ParcelFileDescriptor实现进程间通信

需求 一个通信通道&#xff0c;实现跨进程的的Socket网络通信。 具体的通信通道的图如下。 需求分析 我们需要一个进程一直做通信通道的事情&#xff0c;业务进程把数据通过进程间通信交给通信进程。通信进程通过Socket通道将数据发给网络另外一端的通信进程。接收端的通信进…

RedisTemplate

3.3.RedisTemplate 在Sentinel集群监管下的Redis主从集群&#xff0c;其节点会因为自动故障转移而发生变化&#xff0c;Redis的客户端必须感知这种变化&#xff0c;及时更新连接信息。Spring的RedisTemplate底层利用lettuce实现了节点的感知和自动切换。 下面&#xff0c;我们…

家庭网络防御系统搭建-虚拟机安装siem/securityonion网络连接问题汇总

由于我是在虚拟机中安装的security onion&#xff0c;在此过程中&#xff0c;遇到很多的网络访问不通的问题&#xff0c;通过该文章把网络连接问题做一下梳理。如果直接把securityonion 安装在物理机上&#xff0c;网络问题则会少很多。 NAT无法访问虚拟机 security onion虚拟…

ssm051网上医院预约挂号系统+jsp

网上医院预约挂号系统设计与实现 摘 要 如今的信息时代&#xff0c;对信息的共享性&#xff0c;信息的流通性有着较高要求&#xff0c;因此传统管理方式就不适合。为了让医院预约挂号信息的管理模式进行升级&#xff0c;也为了更好的维护医院预约挂号信息&#xff0c;网上医院…