毕业设计(论文)--基于java学生信息管理系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
江西科技师范大学毕业设计(论文)
学生姓名:
题目(中文):基于Java的学生信息管理系统
(外文):Student Information Management System
based on Java
院(系):数学与计算机科学学院
专业:计算机科学与技术
年级:学号:
指导教师:
时间:2016 年 4 月
2016年4月20日
目录
1.引言 (1)
1.1 项目开发背景和意义 (1)
1.2 国内外的研究现状 (1)
2.系统主要技术及开发环境介绍 (2)
2.1 Java语言 (2)
2.2 Eclipse简介 (2)
2.3 Mysql概述 (2)
2.4 jsp技术概述 (3)
3.系统需求分析 (3)
3.1功能需求分析 (3)
3.2框架结构设计分析 (4)
3.3用户需求分析 (4)
4.系统概要设计 (5)
4.1系统结构图 (5)
4.2系统主要功能模块设计 (5)
4.3程序流程图 (7)
4.4数据库设计 (8)
4.4.1数据库概念结构设计 (9)
4.4.2数据库逻辑结构设计 (11)
5.系统实现 (13)
5.1登录模块系统实现 (13)
5.2基本信息管理实现 (14)
5.3成绩管理实现 (21)
5.4课程管理实现 (23)
5.5班级管理实现 (26)
6.总结和展望 (28)
6.1总结 (28)
6.2 展望 (29)
参考文献 (29)
基于Java的学生信息管理系统
摘要:基于Java的学生信息管理系统分为五大模块:登录管理、学生基本信息管理、成绩管理、课程管理和班级管理。
本文详细介绍了前台界面的操作及后台数据库的链接,根据模块制定各个功能的所需界面的实现方法。
该系统具有十分清晰友好的界面,操作界面简洁,便于使用。
关键字:学生信息管理;MYSQL;JA VA
1.引言
1.1 项目开发背景和意义
随着科学技术的快速发展和不断提高,尤其是计算机科学技术的日渐普及,其功能的强大以及运行速度已经被人们深刻地了解。
近几年来高校的办学模式多元化和学校规模的扩大,为了实现对学生信息进行科学管理,因此开发一个简单快速规范的平台。
学生的信息管理是教务管理的一个至关重要的部分,传统的方法不仅费人力和时间,而且效率低。
如学生发生班级调动,传统的方法需要人工及时更改信息,十分复杂,使得该学生信息不能合理地配置。
而使用计算机技术对学生档案信息进行管理的优点具有便于查找、检索快速、统计科学、保密性强、管理规范、节约成本等优点。
1.2 国内外的研究现状
学生信息管理工作是各大高校必不可少的管理工作之一,在学校占据重要的地位,它涉及到学生、老师和管理员等多方面。
由于各大高校学生人数日益增长,因此研发出一款具有操作灵活且人性化的管理系统成为了迫切需要。
从国外看来许多高校一般是由技术强大稳定的队伍来完成该系统程序的设计与研制,或者是本校的某个院系。
在西方电子管理系统的概念早已被学生引入,他们可以通过网络浏览学校的管理系统网站,以及学校的学术信息等。
可以查看个人信息、考试成绩和课程,这种方式大大地减轻了人力和时间。
从国内研究现状来看,而国内的起步相对较晚,在信息安全和更新方面尚有欠缺,且建立单独的资料共享性差。
随着数字校园理论的逐步应用,各高校不断地开发研制各种办公和教学管理等系统,已经成为了一种全面信息化建设体系。
但是由于程序开发者对于这方面缺少感性认识,基本的工作思路还不是很熟悉,以及各工作环节的内在联系也不是很了解,因此系统功能有受到一定的制约。
整体信息化也相对落后,在购置硬件设施上经费短缺,配套系统不完善使得系统功能得不到全面应用,留下了障碍和瓶颈。
2.系统主要技术及开发环境介绍
2.1 Java语言
Java语言由Sun公司倡导发布,起初名为OAK语言。
它的诞生彻底改变了软件开发行业的模式,该语言功能受到软件程序员的追捧,并成为Internet上使用最为广泛的开发语言。
在任何不同的操作系统和体系布局中,Java虚拟机的实现与编写Java语言都是相关联的。
Java的框架由Java虚拟机、Java API、Javaclass文件和Java语言组成。
2.2 Eclipse简介
Eclipsep平台是IBM公司的跨平台的通用集成开发环境。
该平台是基于C/C++、Java等语言的一个开发环境功能插件,对于其本身,是一个作为开发应用程序的客户端框架平台。
这些功能插件通常有开发工具JDK、JDT、插件开发环境(Plug-inDevelopment Environment,简称PDE)等。
其中较简易好用的一种插件使用是PDE,它是以一组向导的形式来完成插件的创建,在Eclipse平台使用这些插件工作可以更加趋于稳定。
Eclipse平台运行库核心非常小,它是属于微内核。
它在启动时主要负责完成两个任务:管理插件和查找插件的注册表信息,它只在需要的时候才加载该插件,从而减少启动时间和资源空间提高运行效率。
2.3 Mysql概述
Mysql在数据库管理系统中是较出色之一,使用简单、安全可靠、运行速度快等优点被它所占有。
访问Mysql数据库可以利用多种语言编写,并且被大多数用户选择为网站后台的数据库。
Mysql不仅可以在window下运行,也可以在Linux 等操作系统下,使用者可以同根据访问速度及访问量等不同的需求进行选择。
Mysql主要有两种开发模式:B/S和C/S,B/S模式结合VBScript语言,而C/S 模式可以选择VC++和Delphi等开发工具。
为了方便管理维护用户可以自行选择
便捷、开发技术成熟的平台和工具,使得提高软件的生产效率。
Mysql支持的列类型有三种,分别是:日期和时间类、数字类、字符类,在创建数据表的时候,用户需要为每一列选择一种类型。
为了使得数据中的数据能被授权用户访问,管理员必须设置授权表来保护Mysql服务器避免被攻击,因此Mysql数据库采取的安全控制技术有操作平台控制、存取控制、信息流向控制以及加密技术。
2.4 jsp技术概述
JSP网页(*.JSP)指的是在HTML文件(*.HTML)中附加JAVA程序(Scriplet)和JSP标记(tag)。
与ASP相对对比,JSP的跨平台行更强大,可以在windows、Linux系统下正常运行。
当首次打开JSP文件时,JSP引擎会将该文件转换成Java源程序,如果转换成功,JSP引擎利用Javac把该源程序编译成对应的Class文件。
如转换失败,那么转换过程将会中断,弹出语法错误,并且向相应的服务器和客户端发出错误请求,后调用JspSerivce()方法来处理请求。
JSP技术使用的是JavaBeans
或者EJB来执行应用程序,通常使用这种架构来满足大型应用的话不利于维护,因此将基于MVC的Web架构来代替。
3.系统需求分析
3.1功能需求分析
该系统需要完成学生信息管理。
系统在实现上应该具有如下功能:
1.系统要求用户输入正确的账号和密码才能进入系统。
2.系统提供普通用户管理权限,能根据实施情况,对学生基本信息,课程
进行增删改查功能。
3.系统应提供学生成绩的添加、查询和修改功能。
4.系统应提供班级信息的添加和修改功能。
数据库具有一定的安全性,只有管理员才授予全部的权限。
MySQL作为后台数据库,两者相联系,为WEB数据库实现了完美的体系,并且采用JSP技术作为前台,JSP是基于Java Servlet和整个Java体系的WEB开发技术,利用这个技术跨平台建立安全的动态网站,该技术还在不断的优化。
3.2框架结构设计分析
本统采用的是B/S的设计布局,也就是浏览器和服务器架构,示意图如图1所示。
由浏览器提供,接受用户输入的各种操作信息,向服务器端发送各种操作指令和数据请求,并接收执行指令后返回的数据结果,根据业务逻辑进行相关的运算,最后向用户显示相关信息。
服务器负责浏览器端的数据或命令请求,数据库服务器所执行数据库操作得到一个数据集,对该数据集进行对应的处理,然后把数据集或者处理后的数据集传送给浏览器端。
图1系统架构示意图
3.3用户需求分析
(1)学生:学生信息代表着一个学生的身份,比如学生的基本信息(姓名,性别,学号)、学生的成绩、获得荣誉情况、学籍情况和学生班级分配信息等情况,一个学生在校的表现情况是至关重要的。
因此,对信息的管理必须是严密、集中和及时。
(2)高校:随着高校范围的扩大,学生人数日趋激增,学生信息管理也就显得尤为重要。
学院之前对学生信息的管理大多数是人工进行管理,并不是纯粹的自动化管理,这样的话管理人员的任务是非常繁重的,并且容易出错,效率也低。
(3)管理员:院校学生信息管理主要包含用户的信息、课程、班级以及课程管理。
若是人工操作整理这些数据是非常浪费时间和人力资源的,同时后期也不利于管理。
那么开发出具有完整性和系统性的学生管理系统可以方便、准备、快捷地掌握学生的动态。
4.系统概要设计
4.1系统结构图
图2系统结构设计示意图
4.2系统主要功能模块设计
本系统的主要任务就是负责对学生信息管理.主要用户为管理员,管理员拥有所有的权限,可以实现学生信息、学生成绩、课程的添加、删除、查询、修改,以及对学生成绩和人数进行统计操作。
该系统具有十分清晰友好的界面,操作界面简洁,便于使用。
为实现这些功能,系统主要分为如下几个基本模块:
(1)基本信息模块:是管理员对学生信息进行添加操作。
通过本界面管理员可以对学生信息进行相应的修改,包括学号、姓名、生日、密码等。
可以通过该界面输入学生姓名实现查询该学生的所有信息。
管理员可以把学生的整条信息进行删除,同时也删除学生的成绩。
如图3所示。
图3基本信息管理功能模块图
(2)成绩管理模块:是管理员对学生综合成绩进行管理。
包括姓名、学号、平时成绩、期末成绩、总成绩、实验成绩等信息录入,查询,和修改操作,如图 4所示。
图4 成绩管理功能模块流程图
(3)课程管理模块:在该模块可以实现管理员对某个系或班级的课程信息按照学分、课程类型、课程编号、以及学时等条件录入,修改,删除操作。
根据课程
图5 课程管理功能模块图
(4)班级管理:该模块我主要实现了两个功能,即添加班级信息和修改班级信
图6 成绩管理功能模块图
4.3系统数据流图
用户执行每个功能模块的操作时,系统数据库都会对其进行数据库备份和恢复,产生相应的输入和输出流,如查询信息,需提供查询条件,并判定其合法性,然后数据对加工进行流动,提供数据流的数据存储。
通过数据流图可以清楚地看到各实体之间的调用有关系,主要模块的数据流图如下:
图7 学生基本信息管理数据流图
图8 班级管理模块数据流图
图9 课程管理模块数据流图
图10成绩管理数据流图
4.4数据库设计
4.4.1数据库概念结构设计
根据本系统的数据需要分析,列出出以下数据库实体:
(1)学生实体E-R图如图11 所示。
图11学生实体之间关系E-R图
(2)课程实体E-R图如图12所示。
图12课程实体之间关系ER图
(3)成绩实体E-R图如图13所示。
图13成绩实体之间关系ER图(4)班级E-R图如图14所示。
图14班级实体之间关系ER图
(5)管理员实体包括用户名和密码属性,E-R图如图15所示。
图15管理员实体之间关系ER 图
通过本系统各实体间的E-R 图可知,一个学生可以选修对门课程,一门课程也可以被多个学生选修,管理员拥有所有权限,可以对学生的基本信息、成绩、课程进行所有管理操作,总体E_R 图如图15所示:
图16总体E-R 图
4.4.2数据库逻辑结构设计
根据本系统的数据库设计,一共为四张表,具体结构如下:
表1 学生基本信息表
1 N N 1 M N
学生 选课
课程
管理 管理员 成绩
组成 班级 N
表2 教务管理员(tb_user)表表3课程信息表
表4成绩信息表
表5班级信息表
5.系统实现
5.1登录模块系统实现
当打开本系统登录时,会呈现的是用户管理员的登陆界面,如图17所示。
这时用户管理员可以在界面上输入正确的用户名和密码,用户名和密码相匹配,即可直接打开登陆成功的管理员操作主界面,如图5-2所示。
如果用户名和密码错误,则无法登陆。
当选择“重置”的时候,可以把文本框中的数据重置,此时可以重新输入用户名和密码。
图17 登录
在用户登录页面中设计使用了表格,通过表格才能让各个元素在页面中对齐,使
得整个页面显得干净,给人以美感。
相关代码如下:
5.2基本信息管理实现
当管理员信息通过之后,就可默认进入学生信息列表页,设计在页面的左上角显示用户名,“重新登录”可以返回登录页面,同时退出该系统。
右上侧展示出相应的系统功能,如学生基本信息、课程管理、成绩管理、班级管理,用户根据需要选择功能会跳转到相应的页面,下面显示页码及跳转页面的功能按钮。
操作界面如图18所示。
图18 学生信息主界面
(1)添加学生信息
此功能主要对学生信息进行添加,管理员点击“添加”按钮进入新增学生信息界面,如图19。
在此模块姓名、学号、密码不能为空,否则无法对学生信息进行添加,弹出错误提示。
图19新增学生信息
相关代码如下:
(2)修改学生信息
修改学生信息也是有管理员完成的,学校每学期都会对学生的信息进行刷新数据,比如说有些学生入学的信息录入可能会产生错误,有些学生也可能休学或中途退学,也有些学生获得惩罚与奖励等。
这些信息都需要管理员及时地进行修改或者添加,那么通过本系统就可以很方便快捷地完成工作。
管理员点击“编辑”按钮进入修改操作,在操作之前必需先选中要修改的学生复选框,否则弹出“请选择要编辑的学生!”提示框。
如图20所示。
图20 选择要编辑的学生
图21 修改学生信息相关代码如下:
(3)查询学生信息
在此系统的主界面中管理员用户单击“查询”,可以对某个学生进行信息查询,跳转到如图22,在该查询界面中输入学生的姓名和验证码,单击“查询”既可完成操作,将显示符合条件的学生信息。
如图23所示。
图22 查询学生信息
图23 查询学生信息结果
相关代码如下:
(4)删除学生信息
当学生离校,管理员需要删除不需要的学生信息,点击“删除”按钮后会弹出提示“请选择要删除的学生!”对话框。
所以删除操作的前提需要先选中再点击“删除”即可删除所选中的学生信息。
同时也可以进行批量删除,选中多条学生信息后再点击“删除”,弹出确认删除提示框,单击“是”出现删除成功的对话框。
如图24所示。
图24 确定要删除的学生相关代码如下:
5.3成绩管理实现
对于学生成绩管理功能,也是本系统的一个重要环节,那么在该模块主要实现三个功能:管理员对学生的考试成绩录入,查询某个学生的成绩,和修改操作。
如平时成绩、期末成绩、总成绩、实验成绩等。
如要删除成绩,则把该学生的基本信息一同删除。
单击主界面的“成绩管理”按钮,可以进入成绩管理,如图25所示,添加成绩如图26所示,修改成绩如图27所示。
图25成绩信息列表
图26 添加成绩图27 修改成绩
相关代码如下:
5.4课程管理实现
主要实现对各门课程编号、课程名称、讲课学时、总学分、课程类型的增删改查,当用户在系统主页选择该菜单,即可进入课程列表进行浏览,如图28所示。
该模块与成绩管理模块类似,定义了六个数据字段,每一步操作都会对数据库进行更新,添加课程如图29所示,修改课程如图30所示,删除课程如图31所示,其中查询课程功能只能根据课程名称的条件进行查询,如图32所示。
图28 课程列表图29 添加课程
图30 修改课程
图31 查询课程
图32 删除课程相关代码如下:
5.5班级管理实现
班级管理主要针对了班级名、所属院系、专业名称、班级人数、辅导员、学制等信息的修改和添加操作,当用户在主页点击“班级管理”即可进入,跳转到各班信息列表,然后按照需要对其功能进行执行,其功能类似课程管理,主页面如图33所示。
图33班级信息图34修改班级信息
相关代码如下:
6.总结和展望
6.1总结
本系统的完成,充分体会了程序开发的艰苦,因为我对编写代码程序经验并不是很丰富,存在着很多缺陷,所以进展的的速度缓慢,往往卡在一个错误中几天。
在其中每一个细节都是不可忽略的,一不小心就出错全盘皆输。
在开始系统编写开始的时候,看着别人的界面非常漂亮清晰,于是绞尽脑汁地想自己该怎么动手,总希望自己能早点完善系统。
历时一个月的时间,我终于完成了本毕业设
计,经过这次学习,不仅我了解了JSP、Myecplice、Mysql和Tomcat等方面的知识,而且对分层设计思想有了更深层的认识。
这次毕业设计的完成,我得到很多同学和老师的帮助。
首先我特别感谢我的导师周雪梅,从选题、采集文献、论文大纲到定稿的内容格式修改、最终定稿等各个环节都离不开她的悉心指导,在此我谨向周老师表示诚挚的谢意。
同时还要感谢一起完成毕业论文的同学们,特别是在我调试程序遇到困难时,及时地帮助我一起解决问题。
感谢在整个撰写过程中与我密切合作的同学们,没有你们的帮助我的论文不能得以顺利,在此,我再次向帮助过我的老师和同学们表示真诚的感谢!
6.2 展望
学生信息管理它可以为学校档案、图书、教务、财务、后勤等管理准确地提供学生的信息,同时它也要向教务管理提供课程数据。
这些可以相互对调使用,并且构成一个大系统。
由以上得知,可以明确了解到开发和设计一个学生信息管理是很有需要性的,本次开发和设计符合学校的规定,完成了学校对学生信息管理的方便操作,适用,界面直观等要求。
全面及时给学校主管部门提供信息,方便管理,同时也可以通过校园网共享学生信息和扩展各类应用。
参考文献
[1] 邓良松刘海岩陆丽娜.软件工程[M].西安:西安电子科技大学出版社,2000.11
[2] 闪四清.SQL Server2000实用教程[M]. 北京:人民出版社,2002.6
[3] 蔡剑景楠著《Java Web 应用开发:J2EE 和Tomcat》清华大学出版社
[4] 侯晓强,徐春荣,勾海波.Java服务器编程实例[M].中国青年出版社,2004.53-97页.
[5] JSP 应用开发详解(含光盘) 电子工业出版社 2002.9
[6] 简兆权.一类智能管理信息系统的设计与实现[M].计算机应用研究,1998,15(2):43-45.
[7] 王舒颖. 基于Java技术的学生管理系统研究[D].电子科技大学,2012.
[8] 耿祥义,张跃平,JSP实用教程.清华大学出版社,2003.5.
[9] 蔡翠平等.Java程序设计[M].北京: 清华大学出版社,2002.10
[10] 肖刚.Java Web 服务器应用程序设计[M].西安:电子工业出版社,2001.6
[11] Baron王小东.《高性能MySQL(第2版)》[M].电子工业出版社出版的图书,2010
[12] 罗玉玲.《J2EE应用开发详解》[M].西安:电子工业出版社,2009.6
Student Information Management System based on Java
Abstract: The student information management system based on Java is divided into five modules: login management, student basic information management, performance management, curriculum management and class management. This paper introduces the operation of the front desk interface and the link of the backstage database, and the realization method of the required interface of each function according to the module. The system has a very clear and friendly interface, simple operation interface, easy to use.
Key words: Student Information Management; MYSQL; JA V A。