学生选课系统项目设计方案.docx
《学生选课系统项目设计方案.docx》由会员分享,可在线阅读,更多相关《学生选课系统项目设计方案.docx(38页珍藏版)》请在冰点文库上搜索。
学生选课系统项目设计方案
学生选课系统项目设计方案
一、设计的目的与要求
通过软件开发的实践训练,进一步掌握软件工程的方法和技术,提高软件开发的实际能力,培养工程设计能力和综合分析、解决问题的能力。
具体如下:
1.学习和实践在分析和设计计算机应用系统所需要的知识,包括面向对象的系统分析与设计,编码和测试方面的知识;
2.熟悉自动化的软件开发工具RationalRose2003,并将其运用于软件开发的全过程;
3.进一步加强和提高软件工程文档的编写能力;
4.培养协作能力和团队精神。
二、设计正文
<一>概述
1.1课题题目:
学生选课系统
1.2系统的主要目标:
本系统目标是实现选课系统所需的各种基本功能,包括学生选课、退课功能和教师查看选修课程、提交课程成绩功能以及管理员添加学生、维护学生信息、成绩管理、添加教师、维护教师信息、维护选修课程,还有公用的修改密码等功能。
1.3系统的开发环境及运行环境:
操作系统:
WindowsXPProSP2
建模工具:
RationalRose2003
数据库系统:
SQLServer2000
开发工具:
VisualStudio2005
Web服务器:
IIS+ASP.NET2.0平台
〔二系统需求分析
学生选课系统主要满足来自三方面的需求,这三个方面分别是学生用户、教师用户和管理员用户,也即是三类用户角色。
〔1学生用户是主要的需求者,主要需求功能是查询可选课程、查看自己选课情况及进行选课、退课操作等;
〔2教师用户主要需求功能是查看自己所教授的课程、课程有哪些学生选修、以及利用本系统提交学生的成绩;
〔3管理员用户的功能需求较为复杂,包括对学生信息、教师信息、课程信息进行管理。
在学生信息管理子模块中,实现对学生信息的添加、修改、删除操作,还可以输入查询条件进行查询操作。
在教师管理子模块中,实现对教师信息的添加、修改、删除、查询等操作。
在课程管理子模块中,实
现对课程信息的添加,添加时为其分配任课教师、上课时间和地点,实现对课程的修改、删除、查看某个课程的详细信息等。
本系统将管理员用户、教师用户、学生用户的身份及权限进行严格的划分,让管理员拥有最高权限,可以查看、维护系统中的所有信息,如添加学生,添加课程,修改课程信息等;让教师拥有查看自己开设的课程的信息,以及提交所开设课程成绩的权限;让学生拥有选课和退选的权限;而修改密码模块的权限每个用户都可拥有,用以修改自己的密码信息。
通过进行严格的权限划分,可以更好地进行管理,也可更好地保护用户信息安全。
2.1用例图
图2-1学生选课系统用例图
用例图说明:
〔1系统的外部角色有:
学生用户、教师用户和管理员。
〔2系统主要用例的文档描述:
①学生管理用例:
学生用户可见的功能,包含了选课、退课和查看选课三个用例功能。
②教师管理用例:
教师用户可见的功能,包含了查看学生选课和提交成绩两个用例功能。
③信息管理用例:
管理员可见的功能,这个用例进一步分为三个用例:
学生信息管理用例、教师信息管理用例和课程信息管理用例。
④学生信息管理用例:
信息管理用例可见的功能,实现学生信息的管理功能,包含了添加学生、修改学生信息和删除学生三个用例。
⑤教师信息管理用例:
信息管理用例可见的功能,实现教师信息的管理功能,包含了添加教师、修改教师信息和删除教师三个用例。
⑥课程信息管理用例:
信息管理用例可见的功能,实现课程信息的管理功能,包含了添加课程、修改课程信息和删除课程三个用例。
⑦修改密码用例:
所有用户都可见的功能,用于修改用户的密码信息。
〔3系统用例之间的关系:
①学生管理用例与选课、查看选课、退课三用例之间是包含关系。
②教师管理用例与查看学生选课、提交成绩两用例之间是包含关系。
③信息管理用例与学生信息管理用例、教师信息管理用例和课程信息管理用例之间是包含关系。
④学生信息管理用例与添加学生、修改学生信息和删除学生三个用例之间是包含关系。
⑤教师信息管理用例与添加教师、修改教师信息和删除教师三个用例之间是包含关系。
⑥课程信息管理用例与添加课程、修改课程信息和删除课程三个用例之间是包含关系。
〔4系统关键用例的正常事件流图和异常事件流图
表2-1修改密码用例的正常事件流图和异常事件流图
用例名称
修改密码
参与者
管理员、教师、学生
描述
管理员、教师、学生用户进行密码修改
启动
单击"修改密码"
前置条件
用户成功登录
主事件流
用户
系统
1.进入用户修改密码界面,输入旧密码一次
新密码两次
2.系统检查密码格式是否相符
3.系统检查旧密码是否正确
4.如果正确,进行密码修改,转入密码修改成功界面
异常流
异常流
密码检查未通过
系统
返回密码修改界面,提示旧密码不正确,新密码格式不符,两次不同等密码
异常
用户旧密码错误
表2-2提交成绩用例的正常事件流图和异常事件流图
用例名称
提交成绩用例
参与者
教师用户
描述
提交选自己开设课程的学生的成绩
启动
进入提交成绩界面
前置条件
用户成功登录
后置条件
尚未提交过成绩
主事件流
用户
系统
1.单击提交成绩
2.系统提交成绩页面
3.填写学生成绩,单击提交成绩
5.更新学生成绩,提示提交成功
异常流
异常流
用户已经提交过该门课程成绩
系统
提示该课程成绩已提交,不能再次提交
2.2类图
图2-2学生选课系统类图
类图说明:
〔1BaseUser类是一个系统角色用户的基类,主要方法有两个:
modify<>用于修改用户的密码;
loginCheck<>用于用户登录验证。
〔2Admin类继承自BaseUser类。
〔3Student类继承自BaseUser类,主要方法有:
studentAdd<>用于添加学生;
studentDel<>用于删除学生;
studentUpdate<>用于更新学生信息;
getStudents<>用于获取学生列表。
〔4Teacher类继承自BaseUser类,主要方法有:
TeacherAdd<>用于添加教师;
TeacherDel<>用于删除教师;
TeacherUpdate<>用于更新教师信息;
GetTeachers<>用于获取教师列表。
〔5Course类是一个课程类,主要方法有:
CourseAdd<>用于添加课程;
CourseDel<>用于删除课程;
CourseUpdate<>用于修改课程信息;
GetCourses<>用于获取课程列表。
〔6Elect类是一个选课表类,主要方法有:
elect<>选修课程;
electDel<>退选课程;
getElectInfo<>获取选课信息;
haveSubmit<>检测是否已提交过成绩;
submitScore<>提交成绩。
顺序图
<1>管理员修改课程信息顺序图
图2-3管理员修改课程信息顺序图
<2>学生用户退选课的顺序图
图2-4学生用户退选课的顺序图
<3>教师提交成绩顺序图
图2-5教师提交成绩顺序图
2.3协作图<可选>
<1>学生用户选课协作图
图2-6学生用户选课协作图
<2>教师提交成绩协作图
图2-7教师提交成绩协作图
〔三系统总体设计
3.1设计问题域子系统
学生选课系统是实现学生选课退课、教师提交成绩以及学校教务管理员维护信息的一个平台,整个学生选课系统有前台和后台两部分,共分为4个模块:
管理员模块,教师模块,学生模块和公有模块,分别用于完成各自的功能。
以下为学生选课系统总体设计图和各功能模块说明:
〔1总体设计图
〔2各模块功能
表3-1学生选课系统功能模块表
功能模块
包含子功能模块
功能
管理员模块
学生管理子模块
对学生信息的添加、修改,删除操作
教师管理子模块
对教师的添加,修改,删除,查询操作
课程管理子模块
对课程的添加,添加时为其分配任课教师,上课时间和地点,实现对课程的修改,删除,查看某个课程的详细信息等
教师模块
实现查看自己所教授的课程,课程有哪些学生选修,以及利用本系统提交学生的成绩
学生模块
实现学生选课,查看所选课程,修改自己的选课信息
公有模块
实现用户的身份验证,密码修改,退出系统等功能
3.2设计数据管理子系统
〔1数据库表
表3-2数据库表
序号
数据库表
数据表存储的容
1
Student
存储学生的信息
2
Teacher
存储教师的信息
3
Users
存储管理员的信息
4
Elect
存储选课的信息
5
Cource
存储课程的信息
6
Depart
存储学校系院信息
〔2数据表之间的关系
图3-2数据表之间的关系图
①学生表Student的详细数据字段:
表3-3Student学生用户表
序号
字段名
字段类型
说明
备注
1
Stu_ID
nvarchar<20>notnull
学生学号
关键字
2
Stu_Pwd
nvarchar<20>notnull
学生密码
3
Stu_Name
nvarchar<20>notnull
学生
4
Stu_Depart
int
学生系院号
5
Stu_Grade
int
学生年级
6
Stu_Class
int
学生班级
②教师表Teacher的详细数据字段:
表3-4Teacher教师用户表
序号
字段名
字段类型
说明
备注
1
Tea_ID
nvarchar<20>notnull
教师编号
关键字
2
Tea_Pwd
nvarchar<20>notnull
教师密码
3
Tea_Name
nvarchar<100>notnull
教师
4
Tea_Depart
Int<4>
教师系院号
③课程表Course的详细数据字段:
表3-5Cource课程信息表
序号
字段名
字段类型
说明
备注
1
courseID
nvarchar<20>notnull
课程编号
关键字
2
teaID
nvarchar<20>notnull
教师编号
关键字
3
courseName
nvarchar<100>notnull
课程名称
4
courseTime
nvarchar<20>
上课时间
5
courseAddress
nvarchar<50>
上课地点
6
courseInfo
Text
课程简介
④选课表Elect的详细数据字段:
表3-6Elect选课信息表
序号
字段名
字段类型
说明
备注
1
stuID
nvarchar<20>notnull
学生学号
关键字
2
courseID
nvarchar<20>notnull
课程编号
关键字
3
teaID
nvarchar<20>notnull
教师编号
关键字
4
Score
int
课程成绩
⑤系统管理员表Users的详细数据字段:
表3-7Users管理员表
序号
字段名
字段类型
说明
备注
1
adminName
nvarchar<20>notnull
系统管理员用户名
关键字
2
adminPwd
nvarchar<20>
系统管理员密码
⑥系院表Depart的详细数据字段:
表3-8Depart系院表
序号
字段名
字段类型
说明
备注
1
departID
Intnotnull
系院号
关键字
2
departName
nvarchar<100>
系院名称
3.3设计人机交互子系统
〔1用户分类
本系统的用户可分为三类:
①管理员用户;
②教师用户;
③学生用户。
〔2用户描述
①管理员用户的描述:
管理员用户在整个选课系统中起到管理和维护的作用,对学生和教师的信息进行管理和维护以及开设课设等职责。
②教师用户的描述:
教师用户在本系统中具有管理选修了自己开设的课程的学生的权限,查看选修了自己开设课程的学生信息有及提交学生成绩。
③学生用户的描述:
选课系统主要是针对管理学生的,学生在本系统中具有修改自己的信息,以及选课和退选的功能。
〔3设计命令层次
①系统的人机交互子系统的容和准则:
本学生选课系统的人机交互子系统在根据不同的用户身份登陆到不同的页面,然后按照不同的用户只能进行用户权限的操作,其结构图如下:
②通过采用树形结构,细化命令的组织方式,如下:
〔四.详细设计
学生选课系统是实现学生网上选课、教师提交成绩以及学校教务管理员维护信息的一个平台,整个学生选课系统共分为4个大模块:
管理员模块,教师模块,学生模块和公有模块,其中复杂的方法和模块的详细设计流程图如下。
4.1系统用户登录流程图
4.2用户密码修改流程图
4.3教师提交成绩流程图
4.4管理员添加课程流程图
4.5学生选修课程流程图
〔五系统实现
本系统采用了三层架构来实现,即分为用户界面层〔UI、业务逻辑层〔BLL和数据访问层〔DAL,用户界面层是展示给用户的界面,方便用户与系统进行交互;业务逻辑层是对系统业务实体的封装,完成系统业务功能;数据访问层直接与数据库打交道,为业务逻辑层提供底层的数据库操作。
5.1Database类主要是与数据库连接,提供数据库操作功能,代码如下:
namespaceMyElectCourse.DAL
{
publicclassDatabase
{
protectedstringconnectionString;
protectedSqlConnectionconnection=null;
publicDatabase<>
{
connectionString=ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString.ToString<>;
}
~Database<>
{
if=null>
{
connection=null;
}
}
protectedvoidOpen<>
{
if
{
connection=newSqlConnection;
}
if>
{
connection.Open<>;
}
}
protectedvoidClose<>
{
if=null>
{
connection.Close<>;
}
}
publicintExecuteSQL
{
intcount=-1;
this.Open<>;
SqlCommandcmd=newSqlCommand;
count=cmd.ExecuteNonQuery<>;
this.Close<>;
returncount;
}
publicDataSetGetDataSet
{
this.Open<>;
DataSetds=newDataSet<>;
SqlDataAdapteradapter=newSqlDataAdapter;
adapter.Fill;
this.Close<>;
returnds;
}
publicDataTableGetDataTable
{
DataSetds=this.GetDataSet;
DataTabledt=newDataTable<>;
if0>
{
dt=ds.Tables[0];
}
returndt;
}
publicSqlDataReaderGetDataReader
{
this.Open<>;
SqlCommandcmd=newSqlCommand;
SqlDataReadersdr=cmd.ExecuteReader;
//this.Close<>;
returnsdr;
}
}
}
5.2UserBase类是所有系统角色用户的基类,完成用户登录验证与修改密码的功能,代码如下:
namespaceMyElectCourse.BLL
{
publicclassUserBase
{
privatestringuserID;
publicstringUserID
{
get{returnuserID;}
set{userID=value;}
}
privatestringuserPSW;
publicstringUserPSW
{
get{returnuserPSW;}
set{userPSW=value;}
}
publicstringloginCheck
{
StringselectStr=String.Empty;
switch
{
case"0":
//身份为教师时
selectStr="Select*fromTeacherwhereteaID='"+uid+"'";
break;
case"1":
//身份为学生时
selectStr="Select*fromStudentwherestuID='"+uid+"'";
break;
case"2":
//身份为管理员时
selectStr="Select*fromUserswhereadminName='"+uid+"'";
break;
default:
returnnull;
}
Databasedb=newDatabase<>;
DataTabledt=db.GetDataTable;
if
0>//如果该用户存在
{
if
.Equals>//密码正确
{
switch
{
case"0":
//身份为教师时
return"0";
case"1":
//身份为学生时
return"1";
case"2":
//身份为管理员时
return"2";
default:
returnnull;
}
}
else//密码错误,给出提示信息!
{
return"-1";
}
}
else//用户不存在或用户名输入错误
{
return"-2";
}
}
publicstringmodifyPWD
{
StringupdateStr=String.Empty;
switch
{
case"0":
//身份为教师时
updateStr="updateTeachersetteaPwd='"+newPwd+"'whereteaID='"+uid+"'";
break;
case"1":
//身份为学生时
updateStr="updateStudentsetstuPwd='"+newPwd+"'wherestuID='"+uid+"'";
break;
case"2":
//身份为管理员时
updateStr="updateUserssetadminPwd='"+newPwd+"'whereadminName='"break;
}
stringucheck=this.loginCheck;
if||ucheck.Equals<"1">||ucheck.Equals<"2">>
{
intt=newDatabase<>.ExecuteSQL;//根据修改后返回的结果给出提示
if0>
{
return"1";
}
else
{
return"0";
}
}
else
{
return"-1";
}}}}
5.3系统登录页面,代码及运行效果如下:
登录页面"leftmargin="0"rightmargin="0">
12px;font-family:
Tahoma;border-collapse:
collapse"
center">
24pt;font-family:
隶书">学生选课系统
|
宋体">用户名:
| 242px">
TextBoxID="txt
展开阅读全文
相关搜索
资源标签