网上选课系统论文Word文件下载.docx
《网上选课系统论文Word文件下载.docx》由会员分享,可在线阅读,更多相关《网上选课系统论文Word文件下载.docx(31页珍藏版)》请在冰豆网上搜索。
3.3编码………………………………………………………………..20
3.4软件测试………………………………………………………….28
第四部分体会……………………………………………………………………30
第五部分参考文献………………………………………………………………31
前言
二十一世纪是知识经济的时代,同时也是科技高速发展、网络信息迅速膨胀的年代,大量客观事实表明,一个崭新的计算机时代必将到来。
随着知识经济革命的到来和信息技术的蓬勃发展,计算机技术和通讯技术成为了这个时代的主角,不仅改变了我们的世界,而且同时也吹响了我们迈向新生活的号角,正以日新月异的速度改变我们的人生。
而两者的结合产物---计算机网络,在最近的几年更是异军突起、迅猛地发展起来,它不仅提高我们的工作效率,而且还为我们提供了广阔的资源利用空间和方便快捷的现代通讯手段,同时它还是衡量一个国家科技发展水平的重要的尺度。
随着计算机技术和网络技术的发展,各高校相继建成了自己的校园网,并充分利用校园网提供的新环境、新手段为校园的教学、科研和教务管理服务。
近年来,学校的招生规模不断扩大,在学校学生人数明显增多,加之学生分校区管理,给原本繁杂的院级选修课工作增加了不少教务工作量。
网上选课系统的推出,使得选修课程的设置维护、学生选/退课及成绩查询、管理员对选课情况的管理等工作均能在互联网上完成。
这不仅减轻了教务人员的工作负担,也大大方便了全校师生对选课信息的维护、查询。
计算机语言是开发计算机软件的一种高级软件,它的掌握和使用是高级的计算机使用者必须的技能。
现在存在着大量的计算机语言,而且它们的发展速度让世人瞩目震惊。
本系统采用C#数据库编程。
C#是一种重要的新语言,微软将其设计和定位成.NET战略的一部分,C#内建了很多有用的库,并由高级集成开发环境提供支持。
它有效地支持目前占主导地位的编程方法——面向对象编程(OOP)。
C#问世于20世纪90年代,是继C语言之后的一种功能强大的现代语言,它在C的基础上增加了“类”的概念,类是提供用户自定义类型的一种机制,这些用户自定义类型也称为抽象数据类型。
C#通过这些方式和提供继承及运行时类型绑定,来支持面向对象编程。
服务器端采用SQLServer2000关系数据库,SQL语言是1974年由Boyce和Chamberlin提出的。
由于它功能丰富,语言简捷倍受用户及计算机工业界欢迎,被众多计算机公司和软件公司所采用。
经各公司的不断修改、扩充和完善,SQL语言最终发展成为关系数据库的标准语言。
SQLServer2000是一项全面完整的数据库与分析产品。
从借助浏览器实现的数据库查询功能到内容丰富的扩展标记语言(XML)支持特性均可有力地证明,SQLServer2000无谓为全面支持Web功能的数据库解决方案。
与此同时,SQLServer2000还在可伸缩性与可靠性方面保持着多项基准测试记录。
第一部分关键技术概述
本网上选课系统分为客户端和服务器两层结构,服务器端安装了SQLServer2000关系数据库,客户端通过校园的局域网连接服务器的数据库存取数据。
客户端分为供学生使用的学生子系统和供教师使用的管理员子系统。
本系统设计主要用到以下几个关键技术:
XML文档处理技术,遍历DataSet的编程技术,TreeView控件动态绑定数据的技术和遍历TreeView控件的技术等。
1.1XML文档对象模型
文档对象模型(DocumentObjectModel,简称DOM)是XML文档的内存(缓存)中树状表示形式,允许对该文档的导航和编辑。
DOM是程序员能够以编程方式读取,操作和修改XML文档。
VisualC#.NET中,.NETFrameworkSDK中的命名空间System.Xml中封装的XmlNode类能够很好的表示DOM树的节点(Node)。
XmlDocument类继承和扩展于XmlNode类,而XmlNode是组成DOM树的最基本的元素,因此使用XmlDocument类可以创建和访问DOM。
XmlDocument类主要有两类成员方法:
●用于对整个文档对象模型执行操作,例如,将XML文档加载到内存中或将XML文档对象模型保存成一个XML文档。
●查看和操作整个XML文档中的节点。
1.2遍历DataSet
DataSet是ADO.NET中的核心对象,它支持断开式,分布式数据存取方案,功能非常强大。
DataSet是数据在内存中的表示形式。
它可以用于多个不同的数据源,包括关系数据库的数据集,本地的XML文档等。
无论数据源是什么,它都会提供一致的关系编程模型。
DataSet中的方法和对象与关系数据库模型中的方法和对象一致。
DataSet由DataRelation集合,ExtendedProperties和DataTable三部分组成集合。
数据都存放在DataTable集合中。
DataTable集合包括零个或多个DataTable对象。
DataTable对象的结构对应数据库表的结构,从数据库选择出来的数据集可以放在DataTable对象里面。
而DataTable对象又由DataRow集合组成,即每个DataTable里面由多个DataRow。
DataRow集合包含表中的数据。
DataRow相当于多维数组,不断改变下标就可以访问整个DataTable里面的数据,改变DataRow集合对象的下标就可以访问不同的DataTable里面的数据,从而可以实现对整个DataSet的遍历。
1.3TreeView控件动态绑定数据
TreeView控件能够以树状的层次结构显示它的节点。
每个节点可能包含字节点。
父节点或包含字节点的节点可以以展开或折叠的方式显示。
如果将TreeView控件的CheckBoxes属性设置为ture,则在显示TreeView时,节点旁边还可带有复选框。
通过设置节点的Checked属性值为true或false,就能以编程方式选定或清除节点。
紧挨着节点文本的左侧可以显示图标,这要通过设置TreeView控件的ImageList属性与希望使用的现有ImageList控件相关联才能给每个节点获取图象。
为了实现数据的动态绑定,需要以编程方式添加节点和移除节点,具体方法如下:
(1)使用树视图Nodes属性的Add方法,代码如下:
TreeNodenewNode=newTreeNode(“Text”);
MytreeView1.SelectedNode.Nodes.Add(newNode);
(2)使用树视图Nodes属性的Rmove方法移除某个节点,或者使用Clear方法清除所有节点,代码如下:
MytreeView1.Nodes.Remove(MytreeView1.SelectedNode);
MyTreeView.Nodes.Clear();
第二部分软件定义时期
随着计算机的广泛应用,各行各业的信息管理都涉及到计算机中。
在软件定义这一阶段我们明确了软件开发的目的,并确定了“学生网上选课系统”开发的总目标。
确定了系统开发的可行性;
导出了实现此系统总目标应采用的策略及系统需完成的各个功能。
本系统开发的目的在于提高学校选课工作的效率,使学生可以灵活的在选课期限内进行选课活动,同时减轻了负责监督,统计学生选课情况的教师的负担。
2.1问题定义
1.从系统的性质看,本系统属于一个关于数据库方面的应用系统。
2.从系统的功能看,本系统主要应完成以下功能:
学生可以查看课程信息,可以在限定时间内选择,退选,增选课程。
管理员可以增加,修改,删除学生信息和课程信息,可以查看选课情况,可以修改选课期限,可以修改选课限制人数。
3.从系统的结构看,本系统分为客户端和服务器端,服务器端安装SQLServer2000关系数据库,客户端由学生子系统和管理员子系统组成。
2.2需求分析
通过询问参与选课的学生及负责选课工作的老师具体总结出网上选课系统需要能够实现以下功能:
●学生和管理员必须通过认证才能登录系统,管理员和学生的权限不一样;
●管理员可以添加,删除和修改学生信息,可以添加,删除和修改课程信息,可以查看选课情况,可以修改选课期限。
●学生可以查看课程信息,只能在限定时间内选修课程,可以查询自己选修课程的情况,在限定的时间之内还可以退选课程或者增选课程。
如果被选课程选修的人数已经达到上限,则学生不能选修该课程。
整个系统的流程是在用户的要求下进行的,学生子系统负责处理学生的选课,退选,增选等事务,并向用户显示操作情况对话框,同时更新数据库中相关表的数据。
管理员子系统负责处理管理员对选课情况的管理,向管理员显示操作情况对话框,同时更新数据库中相关表的数据。
系统的数据流图如下:
Ø
学生子系统
D1课程清单
3
查看
课程
信息
课程信息
查
看
程
信
号
D2已选课程清单
4
已选
2
登录
1
资格
审核
查看已选
学生
学号
密码
选课
D3选课清单
选课信息
5
退选信息
无效期信息
D1学生记录
管理
记录
管理员子系统
修改信息
A
D2课程清单
B
管理员
帐号
D3选课期限清单
C
修改
期限
D4选课清单
6
情况
信号1(A):
修改学生信息信号
信号2(B):
修改课程信息信号
信号3(C):
修改选课期限信号
选课情况
简化的数据字典
(1)口令:
用户身份验证
(2)数据流:
事务=[输入|查询|选课|]
事务=[输入|查询|退选|]
事务=[输入|查询|增选|]
事务=[输入|查询|修改|]
(3)数据库=Courses表+Student表+Department表+Elective表+Admins表+Period表
后台数据库据库采用SQLServer2000,各表完成如下功能:
◆Courses表:
用于存放课程的详细信息。
◆Student表:
用于存放所有学生的资料。
◆Department表:
用于记录开设课程所属院系名称。
◆Elective表:
用于记录学生选课情况。
◆Admins表:
用于记录所有管理员的信息。
◆Period表:
用于设置选课的开始时间和选课的结束时间。
通过对用户提出要求的调查研究,明确了系统设计的目标,确定了系统的基本功能,并分析出数据的流动方向,在此基础之上可以开始着手设计系统,勾画出网上选课系统总体框架。
第三部分软件开发时期
经过软件定义时期以后,就步入了软件的开发时期。
在此过程中,要尽量寻求实现此系统的最佳方案,进而实现系统的要求。
3.1总体设计
设计原理
本系统是C/S(客户端/服务器)两层结构.
服务器采用SQLServer2000关系数据库.数据库里存放着编译好的存储过程,主要负责数据的存取,也负责一些的业务逻辑的处理,例如判断学生是否在允许时间段内选课.
客户端包含两个系统:
学生选课子系统和管理员管理子系统.学生子系统安装在学校公共机房,图书馆等场所的电脑上,供学生选课时使用,通过局域网访问教务处办公室的服务器;
管理员子系统安装在教务处办公室的桌面型电脑上,供管理教务的教师使用.
学生选课
子系统
后台数据库
系统
管理员管理
应用系统结构图
客户端的设计
学生选课子系统结构图:
学生选课子系统
查看课程
选修
退选
各模块完成以下功能:
查看课程信息:
学生登录后,查看可供选择的课程信息。
查看已选课程信息:
学生登录后,查看自己选择了哪些课程。
选修课程:
学生登录后,通过此模块完成选课操作。
退选课程:
学生登录后,通过此模块完成退选操作。
管理员子系统结构图:
查看选课
修改课程
管理课程
管理学生
管理学生记录:
管理员登录后,可以删除,修改,增加学生信息。
管理课程记录:
管理员登录后,可以删除,修改,增加可选课程信息。
修改课程期限:
管理员登录后,可以修改选修课程的开始及结束日期。
查看选课情况:
管理员登录后,可以查看某门选修课已选人数是否达到限选人数,并可以查看总体选课情况。
数据库的设计
本系统后台数据库建立6个表:
Courses表,Students表Departments表,Elective表,Admins表,和Period表。
1.Courses表
2.
Name
DataType
Size
CourseID
int
CourseName
varchar
50
DepartmentID
CourseHours
CourseScore
CourseTeacher
UpperLimitStudentNumber
SelectedStudentNumber
2.Student表
StudentID
StudentNumber
nvarchar
Password
3.Departments表
DepartmentNume
4.Elective表
ElectiveID
5.Admins表
AdminID
UserName
6.Period表
PeriodID
BeginTime
datetime
8
EndTime
Note
3.2详细设计
到了确定应该怎样具体的实现所要求的系统的时候了,这个阶段将得出学生选课系统的精确描述,从而在编码阶段可以把这个描述直接翻译成具体的程序设计语言书写的程序,这一阶段的结果直接决定了最终程序代码的质量。
1.人机界面设计
本系统对每一层都设置了确保安全的障碍和入口,用户只有进入了某一层才能获得相应那一层资源的访问权,这些措施保证了选课系统及具体数据的安全性。
任何一位Web用户在进入选课系统主页面后,只有通过了系统的身份验证才能进入到系统相应的功能页面完成所要进行的操作。
本系统主要包含以下界面:
从此界面,可以分别进入管理员子系统、学生子系统登录界面,单击查询可以查看课程信息并可以查看打印预览。
在该界面学生输入学号、密码,单击登录按钮系统进行验证身份,如学号、密码与数据库中的记录吻合,则进入下一个界面,进行选课。
管理员登录后,可以添加课程、查看选课情况、对学生记录进行管理等,本界面为学生管理界面,管理员输入学生学号,单击查找按钮,在姓名和密码栏中显示该学生的信息,单击修改按钮或删除按钮,就可以完成相应操作。
在添加学生记录一栏中填写相应信息,单击添加按钮,该学生信息就可以添加到数据库中。
用户可以从主页直接进入成绩查询界面,用户可以通过此界面查看课程信息,分别可以按系、按课程名称、按授课教师等查询课程信息,这样大大方便了各级用户,使用户可以更直接、更方便的了解各门课程,有利于学生快速、准确的选课,同时也有利于管理员对课程的管理。
通过打印预览子菜单,用户可以将所需信息打印出来。
本报表的制作采用CrystalReportDesigner,CrystalReportsforVisualStudio.NET是内置于VisualStudio.NET的报表设计工具,它能够在.NET平台上创建高复杂度且专业级的互动式报表,其以CrystalReport8.0的架构为基础,并且针对.NET平台作更进一步的强化与发展,以确保能提供.NET开发人员最丰富且完整的报表功能。
本系统利用此报表反馈出各系开设课程信息,既方便了学生选课,又减轻了管理员的管理负担,并同时提供打印功能,方便了管理员对局域网上各系开设课程总体情况的掌握。
制作报表过程如下:
首先在原有项目下创建新的窗体,从“工具箱”的Windows窗体选项卡中将CrystalReportViewer报表查看器控件拖放至窗体上,然后从“项目”菜单中选取“添加新项”指令,选择添加CrystalReport项,接下来选择作为空白报表一项,单击确定,即可编辑具有自己独特风格的报表了。
需要说明的是:
报表的数据源可由窗口左侧的数据库文件直接设定。
此界面为配置管理界面,管理员通过相关操作,可以直接修改数据库中的选课时间记录。
在文本区键入选课开始、结束时间,单击生成按钮,配置文件生成功,为更新数据库作好第一步准备。
单击读取按钮,将配置文件读入内存,以便通过函数调用UpdatePeriod存储过程,更新数据库。
出现更新数据库成功对话框,单击确定按钮,此时数据库记录被修改。
学生必须按照新的选课时间进行选课,使管理员可以动态的、间接的管理数据库,而无须登录到SQLServer2000企业管理器对数据库进行修改。
本网上选课系统共涉及到12个用户界面,以上是具有代表性的几个,单独列出加以说明。
为了提高代码的重用性和封装对存储过程的调用,每个子系统都实现了一个存取数据的公共类,提供本系统使用。
2.过程设计
不同身份的用户拥有对数据库的不同访问权限(具体到对库中每个表的存取操作),学生用户的选/退课权限通过系统应用程序提供给教务管理人员动态设置。
系统程序流程图如下
学生子系统:
开始
未通过
输入学号,密码
通过
资格审核
输出退选成功
查看课程信息
查看已选课程
是
输出选课成功
是否在有效期内
否
停止
输出提示信息
管理员子系统
修