《毕业设计(论文)基于web的教师教学辅助系统的设计与实现.doc》由会员分享,可在线阅读,更多相关《毕业设计(论文)基于web的教师教学辅助系统的设计与实现.doc(59页珍藏版)》请在三一办公上搜索。
1、学号 xxx xx 大 学 xxx毕 业 论 文论文题目 基于WEB的教师教学辅助系统的设计与实现 姓 名 xx 专 业 计算机科学与技术 指导教师 xx 201x年x月8日目录一、系统概述3二、系统的设计与实现3(一)数据库设计31、逻辑设计32、物理结构设计43、数据库角色分配74、数据库具体实现74-1、新建数据库74-2、新建数据表9(二)系统设计121、学生用户角色功能设计122、教师用户角色功能设计133、页面划分154、编辑Web.Config页175、学生注册页面的实现186、登录页面的实现207、学生母板页的实现248、学生主页面设计259、班组选择页面的设计2610、通知信
2、息页面的设计2811、作业信息页面的设计3012、实验信息页面的设计3213、作业提交页面的设计3314、成绩查询页面的设计3515、教师主页面的实现3816、教师通知页面的实现3917、教师作业页面的实现4218、教师实验页面的实现4519、教师成绩页面的实现4820、教师信息修改页面的实现55(三)系统实现57三、开发体会57四、参考文献57一、系统概述(一)、网络教育概况当今计算机信息与网络技术的发展方兴未艾,信息与网络技术的出现,使传统的教育方式受到挑战,从而促进了教育思想、教育方法、教育手段的更新,使教育方式发生了巨大的变化。特别是web技术的发展,带来了教育观念的革新,传统的以教师
3、、课堂、书本为中心的教学模式不能适应信息社会的需要,而以基于web技术的计算机网络辅助教学为代表的现代教育技术正在深刻地影响着教育。构建计算机网络辅助教学系统,为学生学习提供了良好的学习环境,利用Internet开辟远程教学使学生随时随地在网上利用教学课件进行学习、做练习、考试和答疑服务等,从而大幅度提高教学质量和学生自主学习能力,真正实现教学方法和手段的现代化作为一种新的教学模式,网络辅助教学能充分发挥网络在课程教学中的优势,体现以学生为主体、教师为主导的现代教育思想,随着计算机技术和网络技术的不断发展,网络辅助教学得到越来越广泛的应用,如何有效的开展网络辅助教学活动逐渐成为当前课程教学信息
4、化建设关注的重要课题,教师教学辅助系统的建设成为解决这一课题的基础和关键。本系统是基于WEB的课程教学系统,它提供了授课教师与学生之间的一个交流平台。通过本平台,学生可以进行课程信息查询、班级选择、作业提交、重要通知查看、得分查询等操作;教师可以进行课程信息输入、班级调整、通知发布、分数录入等操作。本系统在Visual Studio 2008平台上使用.NET3.5+Visual C#+SQL Server 2005简体中文开发版进行开发,并在IIS5.1上进行发布。在开发过程中用到的关键技术有ADO.NET数据库访问技术、Cookie编程技术、WEB窗体应用程序开发技术及ASP.NET We
5、b应用程序开发技术。系统分为教师页面、学生页面、公共页面3部份,教师页面分为教师主页面、班级信息查询、作业具体信息、作业信息输入、作业信息列表、作业成绩输入、作业提交查询、实验信息输入、实验信息查询、成绩查询、成绩输入、通知列表、发布通知、添加教师等内容;学生页面部分分为学生主界面、课程介绍、新用户注册、用户注册信息、班级选择、实验信息查询、成绩信息查询、提交作业、作业要求列表、作业具体要求、通知列表等内容;公共页面分为用户登录、通知内容两个内容,主要用于教师和学生登录及显示某条通知的具体内容。一、系统概述基于Web的教师教学辅助系统是基于WEB的教务实验课选课系统,它提供了授课教师与选修本课
6、程学生之间的一个交流平台。通过本平台,学生可以进行课程信息查询、班级选择、作业提交、重要通知查看、得分查询等操作;教师可以进行课程信息输入、班级调整、通知发布、分数录入等操作。本系统在Visual Studio 2008平台上使用.NET3.5+Visual C#+SQL Server 2005简体中文开发版(具有与企业版一样的功能,但微软公司已不再提供更新及下载)进行开发,并在IIS5.1上进行发布。在开发过程中用到的关键技术有ADO.NET数据库访问技术、Cookie编程技术、WEB窗体应用程序开发技术及ASP.NET Web应用程序开发技术。系统分为公共页面、学生页面、教师页面3部份,公
7、共页面分为教师登录、学生登录、教师注册、学生注册等内容,主要用于教师和学生注册、登录及相关信息显示;学生页面部分分为学生主界面、课程介绍、班组选择、通知查询、作业信息、实验信息、作业提交、成绩查询、更改个人资料、系统注销等内容;教师页面分为教师主界面、通知界面、作业界面、实验界面、成绩界面、教师信息修改、系统注销等内容。二、系统的设计与实现(一)数据库的设计1、逻辑设计根据系统需求分析定义系统中的实体,并采用E-R图来表现实体之间的逻辑关系。本系统中的用户角色有学生和教师,系统中涉及的实体有实验、班级、作业、通知、成绩。实体与角色之间的关系如图2-1-1所示。图2-1-12、物理结构设计在逻辑
8、设计的基础上,为系统设计了9个数据表,分别说明如下:学生注册表:存储学生的注册信息,包括学号、注册名、注册密码、注册邮箱、注册电话、备注和是否选择了班级7列。具体字段设置如下(Student_login):列名数据类型长度可否为空是否主键是否外键默认值备注S_IDChar20Y学生学号Sl_nameChar20注册名Sl_pwdChar20注册密码Sl_mailboxChar30Y注册邮箱Sl_phoneChar15Y注册电话Sl_memoChar500备注Sl_ifclassbit10是否选择了班级注: Sl_ifclass表示该学生是否已经选择班级,0表示没有选择,1表示已经选择;默认值是
9、0。班级学生表:存储每个班级与学生之间的对应关系,包括班级序号、学生学号、组号、座号4列。学生学号由学生注册表得到,而班级序号、组号、座号由学生自己选择。具体字段设置如下(Class_student):列名数据类型长度可否为空是否主键是否外键默认值备注S_IDChar20YY学生IDClass_idInt4班级序号Group_idInt4班组序号Seat_idChar10座位序号注:S_ID是外键,引用Student_login表中的S_ID列。老师登录表:存储教师的登录信息,包括教师号和注册密码。具体字段设置如下(Teacher_login):列名数据类型长度可否为空是否主键是否外键默认值备
10、注T_IDChar20Y教师IDT_nameChar200注册姓名Tl_pwdChar200注册密码通知信息表:存储老师发布的通知信息,包括通知号、通知标题、通知内容、发布日期、发布对象5列。具体字段设置如下(Notice_infor):列名数据类型长度可否为空是否主键是否外键默认值备注N_IDChar20Y通知序号N_titleChar100通知标题N_contentChar5000Y通知内容Nu_dateDatatime8发布日期Nu_studentChar100全体学生发布对象实验信息表:存储每个实验的详细信息,包括实验序号和实验信息。具体字段设置如下(Lab_infor):列名数据类型
11、长度可否为空是否主键是否外键默认值备注Lab_IDInt4Y实验序号Lab_memoChar5000实验信息作业信息表:存储教师布置的作业信息,包括作业序号、作业标题、作业提交期限、作业要求和备注信息。具体字段设置如下(Exercise_infor):列名数据类型长度可否为空是否主键是否外键默认值备注E_IDChar50作业序号E_titleChar100作业标题Eu_deadlineChar100提交期限E_contentChar5000Y作业要求E_memoChar1000Y备注作业提交表:存储学生提交作业的情况,包括学生号、作业号、作业标题、作业提交时间4列。具体字段设置如下(Exerc
12、ise_update):列名数据类型长度可否为空是否主键是否外键默认值备注Eu_IDChar120作业序号S_idChar20YY学生学号E_titleChar100作业标题Eu_dateDatetime8提交日期注: S_ID是外键,引用Student_login表中的S_ID列。学生成绩表:存储学生的成绩情况,包括学生学号、实验1成绩、实验2成绩、实验3成绩、实验4成绩、课外实验成绩、作业成绩、考试成绩。根据各个实验的成绩可以计算出总的实验成绩,并计算最后的总成绩。具体字段设置如下(Student_mark):列名数据类型长度可否为空是否主键是否外键默认值备注S_IDChar20YY学生学
13、号Lab1_markNumeric50实验1成绩Lab2_markNumeric50实验2成绩Lab3_markNumeric50实验3成绩Lab4_markNumeric50实验4成绩Lab5_markNumeric50课外实验成绩Exercise_markNumeric50作业成绩Exam_markNumeric50考试成绩注:1、根据各个实验的成绩可以计算出总的实验成绩,并计算最后的总成绩;2、S_ID是外键,引用Student_login表中的S_ID;3、各项成绩精度为5,小数位数为1位。成绩权重表:记录各个实验成绩 权重,根据权重计算实验成绩、总成绩。具体字段设置如下(Mark_r
14、ate):列名数据类型长度可否为空是否主键是否外键默认值备注Class_IDChar10Y班级Lab1_rateNumeric50实验权重Lab2_rateNumeric50实验2权重Lab3_rateNumeric50实验3权重Lab4_rateNumeric50实验4权重Lab5_rateNumeric50课外实验权重Lab_rateNumeric50实验成绩权重Exercise_rateNumeric50作业权重Exam_rateNumeric50考试权重注:1、lab1_rate+lab5_rate=1这个权重值为1,就是各个实验的实验成绩*权重得出最后的实验成绩;最后的实验成绩*la
15、b_rate+作业成绩*exercise_rate+考试成绩*exam_rate得出课程的最后成绩。2、各列的精度为5,小数点后边为2位。3、数据库角色分配根据逻辑设计,系统共有两种角色:学生、教师。现定义两种角色具体权限如下两表所示:学生权限表:数据表SelectInsertUptateDeleteStudent_loginClass_studentNotice_infoExercise_updateStudent_markLab_infoExercise_info教师权限表:数据表SlectInsertUptateDeleteStudent_loginClass_studentNotice
16、_infoExercise_updateStudent_markLab_infoExercise_infoMark_rateTeacher_login4、数据库具体实现4-1、新建数据库打开SQL Server Management Studio,连接到SQL Server 2005服务器,在对象服务器中新建数据库course,具体操作如图所示:连接到SQL Server 服务器用鼠标右键单击“数据库”,选择“新建数据库”打开“新建数据库”窗口,新建数据库course4-2、添加数据表(以添加学生注册信息表为例)用鼠标右键单击新建的“Course”数据库,选择“新建查询”打开查询分析器窗口在查
17、询分析器窗口输入建表语句,单击工具栏的“执行”按钮,消息窗口提示“命令已成功完成”,完成向数据库添加数据表。各表建表语句为:学生注册信息表(Student_login)USE course.mdfCREATE TABLE Student_login(s_id char(20) NOT NULL,sl_name char(20) NOT NULL,sl_pwd char(20) NOT NULL,sl_phone char(15) NULL,sl_mailbox char(20) NULL,sl_memo char(500) NULL,sl_ifclass bit NOT NULL CONSTR
18、AINT DF_Student_login_sl_ifclass DEFAULT (0), CONSTRAINT PK_Student_login PRIMARY KEY CLUSTERED (s_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARY班级学生表(class_student)USE COURSE.MDFCREATE TABLE Class
19、_student(s_id char(20) NOT NULL,class_id int NOT NULL,group_id int NOT NULL,seat_id char(10) NOT NULL, CONSTRAINT PK_Class_student PRIMARY KEY CLUSTERED (s_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PR
20、IMARYGOALTER TABLE dbo.Class_student WITH CHECK ADD CONSTRAINT FK_Class_student_Class_student FOREIGN KEY(s_id)REFERENCES Student_login (s_id)GOALTER TABLE Class_student CHECK CONSTRAINT FK_Class_student_Class_student教师注册信息表(teacher_login)USE COURSE.MDFCREATE TABLE Teacher_login(t_id char(20) NOT NU
21、LL,t_name char(20) NOT NULL,tl_pwd char(20) NOT NULL, CONSTRAINT PK_Teacher_login PRIMARY KEY CLUSTERED (t_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARY通知信息表(Notice_infor)USE COURSE.MDFCREATE TABL
22、E Notice_infor(n_id char(20) NOT NULL,n_title char(100) NOT NULL,n_content char(5000) NULL,n_date datetime NOT NULL,nu_student char(100) NOT NULL CONSTRAINT DF_Notice_infor_nu_student DEFAULT (全体学生), CONSTRAINT PK_Notice_infor PRIMARY KEY CLUSTERED (n_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOM
23、PUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARY实验信息表(Lab_infor)USE COURSE.MDFCREATE TABLE Lab_infor(lab_id int NOT NULL,lab_memo char(5000) NOT NULL, CONSTRAINT PK_Lab_infor PRIMARY KEY CLUSTERED (lab_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORE
24、COMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARY作业信息表(Exercise_infor)USE COURSE.MDFCREATE TABLE Exercise_infor(e_id char(50) NOT NULL,e_title char(100) NOT NULL,eu_deadline char(100) NOT NULL,e_content char(5000) NULL,e_memo char(1000) NULL) ON
25、 PRIMARY作业提交表(Exercise_update)USE COURSE.MDFCREATE TABLE Exercise_update(eu_id char(120) NOT NULL,s_id char(20) NOT NULL,e_title char(100) NOT NULL,eu_date datetime NOT NULL) ON PRIMARYGOALTER TABLE Exercise_update WITH CHECK ADD CONSTRAINT FK_Exercise_update_Exercise_update FOREIGN KEY(s_id)REFEREN
26、CES Student_login (s_id)GOALTER TABLE Exercise_update CHECK CONSTRAINT FK_Exercise_update_Exercise_update学生成绩表(Student_mark)USE COURSE.MDFCREATE TABLE Student_mark(s_id char(20) NOT NULL,lab1_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_lab1_mark DEFAULT (0),lab2_mark numeric(5, 1) NOT NUL
27、L CONSTRAINT DF_Student_mark_lab2_mark DEFAULT (0),lab3_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_lab3_mark DEFAULT (0),lab4_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_lab4_mark DEFAULT (0),lab5_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_lab5_mark DEFAULT (0),exe
28、rcise_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_exercise_mark DEFAULT (0),exam_mark numeric(5, 1) NOT NULL CONSTRAINT DF_Student_mark_exam_mark DEFAULT (0), CONSTRAINT PK_Student_mark PRIMARY KEY CLUSTERED (s_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = O
29、FF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARYGOALTER TABLE Student_mark WITH CHECK ADD CONSTRAINT FK_Student_mark_Student_mark FOREIGN KEY(s_id)REFERENCES Student_login (s_id)GOALTER TABLE Student_mark CHECK CONSTRAINT FK_Student_mark_Student_mark成绩权重表(Mark_rate)USE COURSE.
30、MDFCREATE TABLE Mark_rate(class_id char(10) NOT NULL,lab1_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab1_rate DEFAULT (0),lab2_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab2_rate DEFAULT (0),lab3_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab3_rate DEFAULT (0),lab4_rate
31、numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab4_rate DEFAULT (0),lab5_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab5_rate DEFAULT (0),lab_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_lab_rate DEFAULT (0),exercise_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_exercise_rate
32、DEFAULT (0),exam_rate numeric(5, 2) NOT NULL CONSTRAINT DF_Mark_rate_exam_rate DEFAULT (0), CONSTRAINT PK_Mark_rate PRIMARY KEY CLUSTERED (class_id ASC)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON PRIMARY) ON PRIMARYGOALTE
33、R TABLE Mark_rate WITH CHECK ADD CONSTRAINT FK_Mark_rate_Mark_rate FOREIGN KEY(class_id)REFERENCES dbo.Mark_rate (class_id)GOALTER TABLE Mark_rate CHECK CONSTRAINT FK_Mark_rate_Mark_rate(二)系统设计1、学生用户角色功能设计在本系统中,学生可以完成的操作有注册、登录、选择班级、通知查询、作业信息、实验信息、作业提交、成绩查询、个人资料修改等。各项具体功能如下:注册:所有学生均可在本站注册;登录:注册后,先登录才
34、能进入系统;选择班级:事物规定4个班,每个班的上课时间和教学方式不一样,学生可以根据自己的情况进行选择,选择后不可更改;通知查询:查看老师发布的通知;作业信息:了解老师布置的作业情况;实验信息:了解老师布置的实验情况;作业提交:提交老师布置的作业;成绩查询:查看各学员的成绩情况;个人资料修改:修改个人的注册资料。功能流程如图:2、教师用户角色功能设置教师可以完成的操作有查看班级信息、输入实验信息、发布通知、输入学生成绩、查询学生成绩等。各项具体功能如下:成绩管理:对学生的各项成绩进行管理,包括实验成绩、作业成绩、考试成绩、最后的总成绩。通知管理:发布通知,学生可以在学生的主页面看到。作业管理:
35、对有关作业信息进行管理。实验管理:对实验课的情况进行管理。成绩管理:对学员成绩进行管理。功能流程如图:3、页面划分学生用户角色和教师用户角色页面规划如图所示:学生页面规划:教师页面规划:下面将所有页面分为公用页面、学生页面、教师页面3部分,简单介绍每个页面完成的功能。公用页面、学生页面、教师页面如下表所示:公有页面:页面名称对应的中文名称用户完成的功能Login用户登录教师、学生进行登录Course_infor课程介绍教师、学生介绍课程学生页面:页面名称对应的中文名称完成的功能Register学生注册完成学生注册Index学生主界面显示通知信息、个人信息、作业信息S_class_infor班组
36、选择查询某个班级信息,并且可以加入该班S_notice通知查询查询教师发布的通知Exercise_infor作业信息查看教师发布的作业S_lab_infor实验信息查看教师发布的实验Exercise_upload作业提交学生上传完成的作业S_exercise成绩查询学生查询自己的成绩Login_infor个人信息个人信息修改Student_master母板页学生页面母板教师页面:页面名称对应的中文名称完成的功能Index老师界面教师信息、通知信息等Teacher_note通知界面教师发布的通知Teacher_exercise作业界面教师布置的作业T_lab_infor实验界面教师布置的实验内容
37、Teacher_mark成绩界面成绩录入查询等T_login_infor教师信息修改教师个人信息Teacher_reg教师注册教师注册个人信息Teacher_master母板页教师页面母板页4、编辑Web.Config页在具体编程之前,先对Web.config页进行编辑,在Web.config页中可以定义Web应用程序中的全局变量。在Web.config文件中定义全局变量有两大优点。一是减少代码量,这样做将全局变量集中存储在一个文件中,而不是在网站的每个页面上都重复这样的操作。二是无需重新编译应用程序即可更新应用程序的某些属性。当想把数据库迁移到另外一个不同的服务器时,只需要修改Web.con
38、fig文件中的数据库连接配置信息,并不需要重新编译和部署这个应用程序以适应新的服务器的要求。ASP.NET35中,在标记“”和“/”之间添加全局变量,是用来添加数据库连接字符串,代码如下: 5、学生注册页面的实现本页面主要使用到验证控件、TextBox控件、Buttom控件和Label控件,具体页面布局如图:注册页面的流程如图所示:提交按钮的实现代码如下:protected void Button1_Click(object sender, EventArgs e) /判断是否已注册 string strSQL = SELECT s_id FROM Student_login WHERE s_
39、id=Number; SqlConnection cn = new SqlConnection(ConfigurationManager.ConnectionStringsConnectionString.ConnectionString); SqlCommand cmd = new SqlCommand(strSQL, cn); cmd.Parameters.AddWithValue(Number, Number.Text); cn.Open(); var dr = cmd.ExecuteReader(); if (dr.Read() /Label2.Text = 该学号已注册,请到登录页面登录!; cn.Close(); Panel1.Visible = false;