《基于JSP的教务管理系统设计.doc》由会员分享,可在线阅读,更多相关《基于JSP的教务管理系统设计.doc(64页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-date基于JSP的教务管理系统设计基于JSP的教务管理系统设计 教务管理系统的设计与实现摘 要教务管理是学校的教务工作的主要内容,其信息量大、信息变动频繁历来是各学校的头疼问题,随着人们对用计算机的使用越来越广泛以及互联网络普及,教务管理也已经基本形成了多元的网络化管理,极大的方便了广大师生,也方便了学校对教务工作的管理,大大的提高了教学质量。本系统采用FlexBuilde
2、r、MyEclipse结合MySQL数据库进行设计,从管理和使用的角度分为两个部分:学校教务管理端和学生使用端。前者主要有系统管理员及任课教师使用,后者则是主要面对在校学生。本文首先作教务管理系统的功能需求分析,然后对数据库进行需求分析,再在数据库中建立相应的表,并弄清楚数据库中各个表的逻辑关系,接着编写代码,最后调试网站,直到形成用户满意的可以使用的完整系统。关键词: 教务管理系统; FlexBuilder; MyEclipse; MySQLThe Design and Implementation of EducationalAdministration SystemAbstractAca
3、demic Senate, the school management is the main content, it is informative, information has always been the frequent changes in schools of headache problems, as people used more and more extensive use of computers and the popularization of the Internet, educational administration has been basically
4、formed a multi-network management, a great convenience to teachers and students, but also on the Senate to facilitate the work of the school management, greatly increased the quality of teaching.The system uses a FlexBuilder, MyEclipse combination of MySQL database design, from the perspective of ma
5、nagement and use is divided into two parts: School of Educational Administration and students to use the client side. The former are mainly system administrators and classroom teachers to use, while the latter is the major problems encountered in school.In this paper, first of all, make the function
6、s of educational management system needs analysis, then the database needs analysis, and then in the database corresponding table, and each database table to clarify the logic of relations, and then write code, debug the final site, until the formation of customer satisfaction The complete system ca
7、n be used.Keywords: Educational Administration system; FlexBuilder; MyEclipse; MySQL目 录1 绪论11.1 课题的研究背景与意义11.1.1 课题的研究背景11.1.2 课题的研究意义11.2 系统的定义及内容简介11.2.1 系统的定义21.2.2 系统的内容简介22 系统中主要用到的技术32.1 MySQL数据库32.2 Flex32.3 Java43教务管理系统的设计与实现63.1 开发和运行环境选择63.2 系统设计63.2.1 系统功能分析63.2.2 系统功能模块设计73.3 数据库设计73.3.1
8、 数据库概念结构设计73.3.2 数据库逻辑结构设计84 模块详细设计114.1 主页面114.2 用户登录页面134.3 学生功能模块设计174.3.1 个人信息查询页面174.3.2 个人信息修改页面214.3.3 在线选课页面224.3.4 密码修改页面274.3.5 历史留言查询页面274.3.6 留言板页面284.4 教师功能模块设计294.4.1 教学实施计划查询页面294.4.2 选课信息查询页面304.4.3 个人信息查询修改页面304.4.4 密码修改页面304.5 管理员功能模块设计314.5.1 教师信息修改、删除页面314.5.2 管理员信息修改、删除页面324.5.3
9、 课程信息添加、修改、删除页面324.5.4 学生学籍查询、修改、删除页面344.5.5 留言查看、删除页面355 用户手册365.1 系统功能简介365.2 系统运行与操作指南366 总结与展望376.1 系统总结及不足之处376.2 设计心得37致 谢39参考文献40附录1 外文参考文献(译文)41附录2 外文参考文献(原文)44-1 绪论1.1 课题的研究背景与意义1.1.1 课题的研究背景目前我国各行各业的信息化建设开展得如火如荼,这种信息化的发展已经影响到了各学校。学校在对学生进行管理时,学生学籍的管理一直都是很麻烦的事情,不仅仅管理起来不易修改和更新,而且学生需要了解本人的信息时,
10、也需要去学校教务处找专门人员。由于这些操作的繁琐性,教务管理系统的开发成为各学校必须的事情,特别是各个高校。一个成功的教务管理系统,应该能够有效地辅助教务人员工作,提高学校学生的学籍、成绩等管理能力,并且不断完善系统,以便更好的帮助学生、教师、系统管理人员等管理成绩、课程、学籍等。然而目前许多教务管理系统在使用时,效率低下容易出错,学生、教师资料不易整理,大量丢失,这些无疑都已成为管理学生学籍、教师信息的障碍。这就要求学校能够建立高效的教务管理系统,对学生的选课、查询等操作及流程进行规范化管理,简化业务流程,提高工作效率并防止中间的漏洞;迅速、准确地捕捉用户要求,并加以高效回应。同时需要不断完
11、善系统,增加模块,更好的满足用户需求,简化教务人员的管理工作,尽量做到一切信息化。 1.1.2 课题的研究意义对于学校教务处而言,最主要的是管理学生的学籍、管理教师的课程教授。如果使用一般的方法来管理,会比较繁琐,管理起来也很有可能出错。为了方便教务人员的管理工作,提高工作效率,同时为了更好地为学生、教师提供服务,有必要开发教务管理系统,使学校的教务管理走上信息化之路,克服人为的种种弊端。教务管理系统的开发不仅可以减少人力、物力和财力资源的浪费,更重要的是有助于提高教务管理的效率。教务管理人员管理学生学籍、管理教师课程教授时是一项复杂的组织工作,这种复杂性不仅仅指学生学籍变更快,变更人数众多,
12、更突出地表现在教务管理主要对象(即学生)的数据量大,管理起来带来不便,所以开发一个实用、高效的教务管理信息系统是很有必要的。1.2 系统的定义及内容简介1.2.1 系统的定义本系统是方便学校教务人员管理学生学籍、管理教师、方便教师和学生处理日常学籍工作而开发的。现今全国各学校的管理系统正逐步与网络信息技术接轨,对学校的学员信息能够更方便地进行管理,运用教务管理系统实现管理模式的科学化、现代化,大大提高学校教务管理的运行效率和管理水平。因此,在科技、信息和网络技术高速发展的带动下,教务管理系统趋向于集计算机网络技术、科学管理方法等于一体,方便处理教务工作。由于学校教务管理的特殊性,决定了教务服务
13、的综合性较其他服务更为突出和特殊,而学校教务对用于辅助管理的管理系统要求就相对更高。对于学校教务而言,具有实用意义的管理系统,在硬件上应采用互联网、办公自动化等信息技术,在软件上应融入当代各学校最优秀的管理思想,从而更好地辅助教务人员的管理工作。本课题就基于教务管理的理念和信息技术的结合这样一个出发点而提出的需要。我国的各学校教师、学生人数众多,学校需要一个足够完善的教务管理系统来管理学生的学籍、选课和教师的授课安排等,所以本系统提供了对学生的学籍管理、对学生的选课、对教师的信息管理等功能,足够教务人员管理日常的教务工作。1.2.2 系统的内容简介教务管理系统为教务管理人员管理日常教务工作提供
14、了方便。学生可以使用此系统查询自己已修完课程的成绩、查看自己的学籍信息、选课等;教师可以使用此系统给学生所选的课程打分、查看自己的信息及课程安排情况等;管理员可以使用此系统添加相关用户信息、备份数据等。因此本系统主要实现学生功能、教师功能、管理员功能。学生功能:个人信息查询、修改;在线选课;密码修改;留言、查看留言等。教师功能:教学实施计划查询;选课信息查询、打分;个人信息查询、修改;密码修改等。管理员功能:教师信息修改、删除;管理员信息修改、删除(有权限之分);课程信息添加、修改、删除;学生学籍信息查询、修改、删除(有权限之分);留言查看、删除(有权限之分)等。2 系统中主要用到的技术2.1
15、 MySQL数据库MySQL是一个遵循GPL的开源软件、在Linux平台底下它是LAMP(LAMP代表了Linux平台上的Apache网站服务器;MySQL数据库以及Perl、Python或者PHP编程语言的结合)组合重要组成部分,同时它提供的C API可以结合Glade/GTK+,代替Windows平台的VB+ACCESS/MS SQL SERVER组合。MySQL数据库具有以下特性: 使用C和C+编写,并使用了多种编译器进行测试,保证源代码的可移植性。 支持AIX、FreeBSD、HP-UX、Linux、Mac OS、Novell Netware、OpenBSD、OS/2 Wrap、Sol
16、aris、Windows等多种操作系统。 为多种编程语言提供了API。这些编程语言包括C、C+、Eiffel、Java、Perl、PHP、Python、Ruby和Tcl等。 支持多线程,充分利用CPU资源。 采用优化的SQL查询算法可以有效地提高查询速度。 既能够作为一个单独的应用程序应用在客户端/服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的GB2312、BIG5,日文的Shift_JIS等都可以用作数据表名和数据列名。 提供TCP/IP、ODBC和JDBC等多种数据库连接途径 。 提供用于管理、检查、优化数据库操作的管理工具。 可以处理拥有上千万条
17、记录的大型数据库。2.2 FlexAdobe Flex是支持RIA(Rich Internet Applications)开发和部署一系列发展中的技术和产品线的概括词,主要包括the Flex Framework,Flex Builder 2,Flex Enterprise Services 2等。FLEX试图通过提供一个程序员们已经熟知的工作流和编程模型,让程序员比从前更快更简单地开发动画及RIA应用。在多层式开发模型中,FLEX应用属于表现层,FLEX的语言和文件结构也试图把应用程序的逻辑从设计中分离出来。Adobe Flex所包含的产品和相关软件如下所述: Flex Framework包
18、括MXML,类库,组件,容器和效果(effects)等,它不需另外的服务器或IDE就可以生成和美化FLEX应用程序。 Flex Builder 2是在Eclipse基础上创建的全新RIA IDE,是生成FLEX应用的最简单最强大的方式,实现了集成编译器、代码缩进、调试、设计视图、源代码控制系统集成等许多功能。它可以当作标准的独立应用软件,也可以当作Eclipse的插件使用。 Flex Enterprise Services 2是Flex 1.5 server的下一代,拥有众多新功能,比如自动测试,企业通信支持(提供一种发布/订阅的通信架构),数据服务(使本地处理的数据和服务器端同步)等。 Fl
19、ex Charting 2提供平滑的数据可视能力,可看作是Flex Framework的扩展。 Flex编译器,被包含于Flex Builder 2和Flex Enterprise Services,但可以在命令行方式下单独使用。 ActionScript 3是Flex Framework的核心,更加面向对象化和类型化,全面兼容ECMA Script标准(Java Script 2.0的基础标准)。 Flash Player,从8.5版本就开始加入AS3虚拟机,作为FLEX 2应用的运行时。 FLEX最初是作为一个J2EE(Java 2 Platform,Enterprise Edition)
20、应用,或者可以说是JSP(Java Server Pages)标签库而发布的。它可以把运行中的MXML(FLEX标记语言)和 ActionScript编译成FLASH应用程序(即二进制的SWF文件)。相对于基于HTML的应用(如PHP,ASP,JSP等)在每个请求时都需要执行服务器端的模板,由于客户端只需要载入一次,FLEX应用程序的工作流被大大改善。新版的Flex Builder 2基于Eclipse IDE,对于需要诸如data push和自动测试等高级功能的用户来说,企业级的服务仍然有效。Flex2引入了新版本的语言ActionScript 3的使用,这需要 Flash Player 9
21、 以上版本作为运行时(runtime)。 2.3 JavaJava是由Sun公司于1995年5月推出的程序设计语言(以下简称Java语言)和Java平台的总称。用Java实现的Hot Java浏览器显示了Java的魅力,可实现跨平台、动态的Web、Internet计算。从此,Java被广泛接受并推动了Web的迅速发展,常用的浏览器现在均支持Java Applet;另一方面,Java技术也不断更新。Java语言是一种简单的,面向对象的,分布式的,解释型的,健壮安全的,结构中立的,可移植的,性能优异、多线程的动态语言。而Java平台由Java虚拟机(Java Virtual Machine)和Ja
22、va 应用编程接口(Application Programming Interface,简称API)构成。Java 应用编程接口为Java应用提供了一个独立于操作系统的标准接口,可分为基本部分和扩展部分。在硬件或操作系统平台上安装一个Java平台之后,Java应用程序就可运行。现在Java平台已经嵌入了几乎所有的操作系统。这样Java程序可以只编译一次,就可以在各种系统中运行。3 教务管理系统的设计与实现3.1 开发和运行环境选择教务管理系统主要用于学校内部资源管理(如学生在线选课、成绩查看、学籍查看等),充分利用现代高度信息化手段来接受学生信息的咨询和反馈,形成目前学校内部受欢迎的教务产品,
23、同时也方便了教务管理人员的管理工作,也方便了学生对自己个人信息的实时了解。1、开发工具的选择用Tomcat作Web服务器,利用My Eclipse设计代码,使用MySQL建立数据库。2、运行环境要求l 中央处理器:Inter Pentium 4 2.67GHz或更高性能的CPU(推荐使用P4 3.0GHz以上)。l 操作系统:Microsoft Windows XP /Vista,或Windows2003(或更高)。l 物理内存:512MB(推荐使用1G以上)。l 硬盘空间:至少需要2G硬盘空间。l 光驱。l VGA监视器。l 鼠标或其他定位装置。l 网络支持:任何与Windows 98/NT
24、/2000/Me兼容的网络。3.2 系统设计3.2.1 系统功能分析教务管理系统主要具有以下功能要求: 学生功能:个人信息查询、修改;在线选课,密码修改;留言、查看留言等。 教师功能:教学实施计划查询;选课信息查询、打分;个人信息查询、修改;密码修改等。 管理员功能:教师信息修改、删除;管理员信息修改、删除(有权限之分);课程信息添加、修改、删除;学生学籍查询、修改、删除(有权限之分);留言查看、删除(有权限之分)等。3.2.2 系统功能模块设计根据系统功能要求分析,可以将系统分解成以下几个功能模块来设计,如图3.1所示。教务管理系统学生管理员个人信息查询、修改教师在线选课密码修改留言、留言查
25、看教学实施计划查询选课信息查询、打分个人信息查询、修改密码修改教师信息修改、删除管理员信息修改、删除课程信息添加课程信息修改删除学生学籍修改、删除留言查看、删除图3.1 系统功能模块图3.3 数据库设计数据库是信息管理系统的基础,数据库的结构直接关系到各种功能的实现和程序运行的效率。3.3.1 数据库概念结构设计数据库概要结构设计图如图3.2所示。图3.2 数据库结构设计图3.3.2 数据库逻辑结构设计根据数据库结构设计图,可知在数据库中需建立8张表。本系统创建的数据库为education,该数据库由学生信息表单(stuinfo)、教师信息表单(teachinfo)、管理员表单(manainf
26、o)、教学实施计划表单(teachingplan)、教学班表单(teachclassinfo)、留言板表单(leavewordinfo)、课程信息表单(courseinfo)、选课信息表单(selectcourseinfo)组成,在设计中所用到的关系表及其结构分别如下所示。1、学生信息表单(stuinfo),如表3.1所示。表3.1 学生信息表单列值数据类型数据长度可否为空描 述主键stu_idvarchar30否学号namevarchar10否姓名passwordvarchar30否密码sexvarchar2否性别specialityvarchar30否专业academevarchar30否
27、学院gradevarchar30否年级overcoursevarchar30否已学课程achievementvarchar30否成绩statusvarchar30否学籍状态2、教师信息表单(teachinfo),如表3.2所示。表3.2 教师信息表单列值数据类型数据长度可否为空描 述主键teach_idvarchar30否教师工号namevarchar30否姓名passwordvarchar30否密码specialityvarchar30否所在专业postvarchar30否职称teachcoursevarchar30否所授课程3、管理员表单(manainfo),如表3.3所示。表3.3 管理
28、员表单列值数据类型数据长度可否为空描 述主键mana_idvarchar30否编号usernamevarchar30否管理员名passwordvarchar30否密码popedomvarchar30否权限4、教学实施计划表单(teachingplan),如表3.4所示。表3.4 教学实施计划表单列值数据类型数据长度可否为空描 述主键idint11否编号是course_namevarchar30否课程名course_kindvarchar30否课程性质begin_termvarchar30否开课学期begin_specialityvarchar30否开课专业periodvarchar30否学时5
29、、教学班表单(teachclassinfo),如表3.5所示。表3.5 教学班表单列值数据类型数据长度可否为空描 述主键idint11否编号是specilityvarchar30否专业gradevarchar30否年级stu_numvarchar30否学生人数course_namevarchar30否课程名6、留言板表单(leavewordinfo),如表3.6所示。表3.6 留言板表单列值数据类型数据长度可否为空描 述主键leave_idint11否留言编号是leave_datedate0否留言日期leave_namevarchar30否留言人姓名leave_contentvarchar20
30、00否留言内容7、课程信息表单(courseinfo),如表3.7所示。表3.7 课程信息表单列值数据类型数据长度可否为空描 述主键course_idvarchar30否课程编号是course_namevarchar30否课程名称8、选课信息表单(selectcourseinfo),如表3.8所示。表3.8 选课信息表单列值数据类型数据长度可否为空描 述主键course_idvarchar30否课程号stu_idvarchar30否选修学生学号teachervarchar30否授课教师achievementvarchar30否成绩4 模块详细设计4.1 主页面此教务管理系统的用户有三种身份,即
31、学生、教师和系统管理员, 如果是系统管理员,登录后进入的主页面如图4.1所示:图4.1 系统管理员主页面此界面中包含五个功能模块,即管理教师、管理员管理、课程信息管理、学生学籍管理、留言维护。系统管理员在此页面中可对教师、管理员及学生等信息进行浏览、修改、删除、添加等操作。如果是登录用户是学生,登录后进入的主页面如图4.2所示。图4.2 学生主页面此页面包含六个功能模块,即选课、个人信息查询、个人信息修改、密码修改、历史留言查询、留言,学生可以在此页面中对其个人信息分别进行浏览、修改等操作。如果是登录用户是教师,登录后进入的主页面如图4.3所示:图4.3 教师管理主页面此页面包含五个功能模块,
32、即教学实施计划查询、选课信息查询和打分、个人信息查询、个人信息修改、密码修改,教师可在此页面中对相关信息进行浏览、修改等操作。4.2 用户登录页面此页面的主要功能是对使用本系统的用户进行用户名、密码、用户身份的验证,只有合法的用户才能使用本系统。对于初次使用本系统的用户,首先必须是在此学校有学籍,而且教务人员已经将学生、教师、管理员信息写入数据库之后才能访问登录用户界面,此系统不支持陌生人注册。在登录界面中设置了身份列表下拉框,方便用户进行身份选择、登录。用户填写的所有信息通过Flex与Java的远程调用,通过send()方法将获取的text文本提交到Java端,并与数据库中的相应信息进行比较
33、做出判断。登录界面如图4.4所示。图4.4 用户登录界面用户登录界面的主要实现代码如下:Event(name=loginevent,type=com.education.events.LoginEvent)Event(name=studentloginevent,type=com.education.events.StudentLoginEvent)Event(name=teacherloginevent,type=com.education.events.TeacherLoginEvent)username.textpassword.texttypes.text4.3 学生功能模块设计学生功能模块主要包括个人信息查询、修改,在线选课,密码修改,留言、查看留言。学生选课,修满学时之后,由授课教师打分,然后学生再次查询信息时则可查询到分数。4.3.1 个人信息查询页面个人信息查询页面如图4.5所示,当前登录的学生可在此页面中查看自己的基本信息。图4.5 个人信息查询页面在个人信息查询页面中,通过studetLO.getTheStudent.send()方法来操作数据库,把数据库中的内容用datagrid显示出