- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
基于NET在线考试系统设计与关键技术实现
基于NET在线考试系统设计与关键技术实现
0 引言
本系统是和西南交大出版社英语阅读教材绑定使用的在线考试系统,在实现一般考试系统具有的优点的基础上,如降低考试成本、实现无纸化办公、教师无须去做考后的阅卷、统计、分析工作等,还实现了学生成绩细粒度的统计,另外系统生成激活码用于考试系统中,提高了系统的安全性,可以打击图书盗版,维护了作者和出版商的合法权益。
1 系统的开发架构
本系统开发平台是VisualStudio2010,实现语言是C#,以IIS作为Web服务器。实现的B/S五层模式:表示层、业务层逻辑、数据持久层、数据访问层和数据库层。表示层是为用户提供服务的图形界面,用于接收用户输入信息和显示信息,是客户端与应用程序进行交互的层次;业务逻辑层是Web服务器,一方面用于处理用户的所有请求,另一方面为用户提供访问数据库的接口,将处理结果展现给用户;数据持久层主要是把数据表映射成实体类,不直接操作数据表,便于面向对象的程序开发;数据访问层负责响应Web服务器发出的SQL请求,实现对数据库的增删改查操作;数据库层主要是指数据库或数据源,本系统采用SQL Server 2008 R2。
2 系统主要功能模块
本系统主要由、管理员、教师、学生三个模块组成。其中学生模块中的考试模块是本系统的核心。
管理员模块主要实现对老师信息,学生信息,院系信息,统计成绩等管理。
教师模块主要实现创建教学班、管理教学班、管理公告、设定考试时间段、统计成绩、评定成绩,修改个人信息等。具体的流程是:老师创建教学班级后,可以发布公告提示学生注意事项,等待学生注册成功后可以对其授权,设定每个单元的考试时间段,学生考试完毕后老师点击评定成绩就可以查看统计结果,包括班级之间的比较,学生的比较,每道小题的比较。
学生考试功能模块的流程是这样的:管理员添加老师信息后,该老师首先要创建班级,并设定考试时间段,以便学生在规定的时间内进行考试。学生要想考试必须先进行注册,注册时选择老师创建的班级,并等待老师对其授权;学生在第一次进入系统进行考试时必须输入书中的激活码进行考试激活,并要求在规定的时间段内进行考试,考试完成后自动统计成绩,学生考完提交成绩后可以马上查看成绩。
3 关键技术LINQ to SQL的实现
考试管理系统综合运用Ajax、Jquery、Linq to sql等目前系统比较流行的技术。其中LINQ to SQL是一个ORM(对象-关系-映射)框架,可以帮助我们将数据表自动生成实体类。数据库技术从OLEDB,ODBC到ADO,在到ADO.NET到现在的LINQ to SQL,让程序员操作数据库越来越简单,LINQ to SQL的入口点是DataContext类,这个类的主要功能是:① 将我们用C#写的查询语句翻译成SQL语句;② 执行查询;③ 连接的管理。这样我们就不用写Connection类了,也不用担心数据库的连接和关闭的问题。
下面以本系统老师密码修改功能的实现介绍一下LINQ to SQL的应用:
1)配置web.config
Initial Catalog=OE;Persist Security Info=True;User ID=sa;Password=1 /
2)新建Linq to Sql类取名OnLineExam,添加数据库连接,将数据表拖入OnLineExam.dbml.生成的dbml部分关系映射图
3)在aspx页面当中通过
$.get(Update_ExamResource.axd, type=updateTeacherPwdte
acherPwd= + $(#password).val() )找到UpdateHandler.cs中对应的方法。
public class UpdateHandler : IHttpAsyncHandler{
public void ProcessRequest(HttpContext context){
NameValueCollection requestInfo = context.Request.QueryString;
string type = requestInfo[type];
switch (type){
case updateTeacherPwd: UpdateTeacherPwd(context);
break;
}
Context.Response.Cache.SetCacheability(HttpCacheability.No
Cache);
}
private void Upd
原创力文档


文档评论(0)