摘 要
班级管理是学校管理的重要组成部分,传统的班级管理方式存在效率低下、信息不及时等问题。为了解决这些问题,本文设计并实现了一个基于 Java 的班级管理系统。
本论文旨在设计并实现一个基于 Java 的班级管理系统,以提高班级管理的效率和准确性。该系统采用了SSM框架,MySQL 数据库作为数据存储,通过 Java 的 Swing 图形界面库进行界面设计,实现了后台首页、系统用户(管理员、班委用户、学生用户)、班级信息管理(班级信息列表、班级信息添加)、班级活动管理、学生信息管理、考勤信息管理、成绩信息管理、奖惩信息管理、系统管理、公告信息管理、资源管理等功能。通过使用本系统,班委可以更加方便地进行班级管理工作,学生也可以更加方便地查询自己的信息和成绩。该系统具有界面友好、操作简单、功能强大等特点,能够满足班级管理的基本需求。
关键词:班级管理系统; Java; MySQL
Design and Implementation of a Class Management System Based on Java
Abstract
Class management is an important component of school management, and traditional class management methods have problems such as low efficiency and untimely information. To address these issues, this article designs and implements a Java based class management system.
This paper aims to design and implement a Java based class management system to improve the efficiency and accuracy of class management. The system adopts the SSM framework and MySQL database as data storage. The interface design is carried out through Java's Swing graphical interface library, which realizes the backend homepage, system users (administrators, class committee users, student users), class information management (class information list, class level information addition), class activity management, student information management, attendance information management, grade information management, reward and punishment information management System management, announcement information management, resource management, and other functions. By using this system, the class committee can more conveniently carry out class management work, and students can also conveniently query their own information and grades. This system has the characteristics of user-friendly interface, simple operation, and powerful functions, which can meet the basic needs of class management.
Keywords: class management system; Java; MySQL
目录
班级管理系统是一种常见的校园管理软件,用于管理学生信息、学生信息、考勤信息、成绩信息、奖惩信息等,为学校和老师提供方便快捷的管理工具。随着教育信息化的发展,班级管理系统的需求也越来越高,同时也面临着一些挑战,如数据安全、系统稳定性等问题。因此,设计和实现一个基于Java的班级管理系统具有重要意义。
随着教育信息化的不断发展,学校和老师对于管理信息系统的需求也越来越高。班级管理系统作为一种常见的校园管理软件,能够帮助学校和老师更加方便快捷地管理学生信息、学生信息、考勤信息、成绩信息、奖惩信息等,提高管理效率和质量。
基于Java的班级管理系统设计与实现的研究,可以为学校和老师提供一个方便快捷的管理工具,提高管理效率和质量。同时,该系统可以通过采用先进的设计和技术手段,解决数据安全和系统稳定性等问题,保障系统的安全性和可靠性。此外,该系统还可以为教育信息化的发展提供有力支持,为教育事业的发展做出贡献。
总之,基于Java的班级管理系统设计与实现的研究,具有重要的理论和实践意义,可以为学校和老师提供一个方便快捷的管理工具,提高管理效率和质量。同时,该系统还可以为教育信息化的发展提供有力支持,为教育事业的发展做出贡献。
目前,基于Java的班级管理系统已经得到了广泛的应用。许多学校和培训机构都采用了班级管理系统来提高教学管理效率。同时,也有许多公司和个人开发了各种类型的班级管理系统,以满足不同用户的需求。
随着人工智能和大数据技术的不断发展,基于Java的班级管理系统也将不断升级和完善。未来,班级管理系统将更加智能化,可以根据学生的学习情况自动调整教学计划和课程安排。同时,班级管理系统也将更加注重数据安全和隐私保护,以保障用户的信息安全。
基于Java的班级管理系统是教育信息化的重要组成部分,得到了广泛的关注和应用。目前,该系统的开发现状良好,未来将更加智能化和注重数据安全。
开发和实施基于Java的班级管理系统的实现,需要完成以下任务:
(1)首先是确定选题,确定好所要做的系统,并对系统的背景及现在面临的一些问题等进行系统的初步确认。
(2)在系统ACK完成之后,我们将根据系统开发的要求,选择SSM技术来构建班级管理系统,并对其中的数据库进行搭建和开发,以确保该系统能够有效地实现其功能。此外,我们还将对所选择的技术进行详细的技术分析,以确保系统的可行性和安全性。
(3)在基于Java的班级管理系统的实现中,首先要确定系统的技术,然后进行在线确认,以确定系统的用户角色,并根据这些角色划分出相应的功能模块。系统的设计主要将用户分为管理员、学生用户、班委用户,每个角色都有其独特的特点,而且每个功能模块都有其特定的功能,但是系统的数据库都是交互式的,学生用户可以随时根据自身的需求查看个人信息、班级信息、班级活动、考勤信息、成绩信息、奖惩信息等,管理员可以快速收集用户的详细信息,并能够在第一时间响应用户的需求。
(4)经过精心设计的系统功能模块已经ACK完毕,接下来就是程序和界面的开发。为了检验程序的完整性,我们会采取多种测试方法,让不同的用户编写和提交相关内容,并定期检查程序中的缺陷,一旦发现问题,立即采取在线解决措施,直至系统运行稳定,才可以将其上传至正式使用。
MySQL数据库已经成为网络上的一种强大的工具,它能够支持多个用户,并且能够根据客户端和服务端的需求进行调整,从而满足不同的需求。在这里,服务端和客户端只是一种软件上的概念,而我们所使用的计算机硬件则没有必要完全相互匹配[1]。
MySQL作为一种备受推崇的关联性DBMS,其卓越的性能和易于操作的特性,以及其在多种操作环境中的灵活性,让其成为了最受青睐的应用之选。此外,MySQL还具有良好的跨平台性,让软件开发人员更加满意。与传统的关联式数据库系统形式大相径庭,MySQL拥有一套完善的数据库管理策略,以确保用户的安全、稳健、安全。MySQL具备良好的容错、安全、快速、稳健的特点,使得mysql成为一款相当流行的数据库管理工具[2]。
MySQL拥有一种独特的权限分配机制,可以根据用户的身份和业务逻辑,为用户提供更多的选择,从而大大提高了MySQL的安全性和完整性,远超过其他关系型数据库。
MySQL具有强大的功能,能够处理各种数据类型,包括动态、静态、多种语言,从而使用户能够轻松访问多种数据。
MySQL具有多种功能[3],它能够支持多种平台的开发,并且支持多种编程语言[4],使得用户能够轻松访问和使用MySQL数据库。
Vue(读音/vjuː/,相似于view)是一种具有高度灵活性的JavaScript架构,能够从基础到顶级,从低到高地实现多种功能,从而创造出一个完整的、高效的用户体验。Vue的核心库专注于视觉表示,它的操作简单,并且可以轻松地将其与其他第三方库和已存在的项目进行集成。此外,Vue可以通过搭配先进的工具和多样的支撑性库,来实现对复杂的网站(SPA)的高效管理。
Vue.Vue作为一种逐步改善的用户体验的框架,具备了独特的优势:首先,它的基础结构更加简单,而且可以轻松地被更多的人使用,而Vue的核心库则更加专注于视觉层,可以轻松地被更多的人使用,也可以被更多的库和现成的项目所使用。Vue 具备强大的功能,可以利用其内置的多个文档组件以及其强大的生态系统,来实现更加精简、高效的单页应用。
Vue.js 旨在通过最少的 API ,实现对数据的有效绑定,并将其转换为多种形式的视图组件。
Vue.js 虽然不是一个完美的框架,但它可以帮助我们更好地理解和实现复杂的页面应用。它的视图层特性使得它更容易学习,并且可以与其他库或已有项目进行整合,从而提高效率。
sun公司的java编写的编译器可以跨越各种不同的操作系统,它的高度可靠的兼容性使它成为当今最受欢迎的编译器之一,它的强大功能使它成为了当今数据中心、个人PC和高端科技电脑的首选编译器,并且拥有一支规模宏大的编译器团队。[5]
sun公司推出的java开发工具JDK,具有极大的功能,如果没有它,java程序将无法正常运行,从而影响到用户的使用体验。[6]
-
- SSM框架
今流行的“SSM组合框架”是Spring + SpringMVC + MyBatis的缩写,受到很多的追捧,“组合SSM框架”是强强联手、各司其职、协调互补的团队精神。web项目的框架,通常更简单的数据源。Spring属于一个轻量级的反转控制框架(IoC),但它也是一个面向表面的容器(AOP)。SpringMVC常常用于控制器的分类工作模式,与模型对象分开,程序对象的作用与自动取款机进行处理。这种解耦治疗使整个系统的个性化变得更加容易。MyBatis是一个良好的可持续性框架,支持普通SQL查询,同时允许对存储过程的高级映射进行数据的优化处理。大型Java Web应用程序的由于开发成本太高,开发后难以维护和开发过程中一些难以解决的问题,而采用“SSM组合框架”,它允许建立业务层次结构,并为这个问题提供良好的解决方案。
在软件开发的过程中,可行性分析是至关重要的,它旨在评估问题的可行性,以便尽可能快地解决,同时也要考虑到不同的解决方案的优势和劣势,以及实施这些方案所带来的经济效益。通过对技术、操作和经济因素的综合考量,我们可以更好地评估基于Java的班级管理系统的可行性,具体表现在:
Java编程语言为基础,结合SSM、Vue等模型,数据库则使用当前最先进的MySQL数据库,这样,基于Java的班级管理系统就能够将其内容完整地保留下来,同时,为提高用户的使用效率,我们还引入Ajax的异步操作,它能够实现对特定数据的快速更改,从而节省服务器的时间,提升用户的使用感受。这个系统的设计非常容易,所以无须进行额外的调整。它使用了Java语言、MySQL存储,并且使用了H5作为前端界面的展现。
通过采用Java和MySQL的架构,基于Java的班级管理系统的开发与维护费用虽然较低,但一旦正式推出,将会带来巨大的收益:既能够让用户更加轻松地获取信息,又能够有效地提高QoS,同时降低运营者的负担。虽然班级管理系统并非特别复杂,但它的制作费用相比较低,而且耗费的时间更少,因为它能够带来更高的效率,而且比起日常的维护与管理,它的收入要更高,因此,它的制作完全符合市场的需求。
这款基于Java的班级管理系统是一款基于浏览器和服务器的软件,它的前台页面简洁易懂,无论是系统管理员、班委用户还是学生用户,只要有网络,只要打开浏览器,就可以轻松访问,而且不需要任何操作指导。由于无需任何复杂的环境配置,这个系统既简单又易于操作,因此它具有极高的实用性和可靠性。
当前,B/S架构的系统提供了一种便捷的数据访问模式:只需点击一下网站,即可获取系统的信息,而且,该信息会被存储,并且会被及时地转交给服务器,从而实现快速、准确的信息交换。班级管理系统由三个层次组成:视觉-模拟-决策。其中,视觉层负责将用户的需求从服务器上转发到用户,同时也负责将用户的需求转化成可执行的行动。而决策层则负责执行与用户需求有关的决策,以及将用户的需求转化成可执行的行动。
学生用户用例图如图3-1所示。
图3-1 学生用户用例图
管理员用例图如图3-2所示。
图3-2管理员用例图
班委用户用例图如图3-3所示。
图3-3班委用户用例图
基于Java的班级管理系统的实现是一个集众多用户信息且长时间持续运转的系统,它储存了大量的信息,所以需要保证数据不会出现泄露、损坏等情况。只有良好的数据安全才可以保证系统对班级管理信息的管理。
由于本系统具有班级信息管理性质,涉及班级信息管理、班级活动管理、学生信息管理、考勤信息管理、成绩信息管理、奖惩信息管理等及时性较强的功能,所以,为了提高用户体验,需要及时反映操作的准确性以及有效性,预计需要控制系统响应时间在3s内,数据传输在50ms以内。
本系统集信息收集与管理功能于一身,除涉及大量信息数据外,还需满足用户和管理员访问。可以预见,这种访问通常是集中的、突发性的访问,这种访问很容易导致服务器满载、迟缓,最终崩溃。所以这要求在软件以及硬件部分均需要拥有应对短时间内大量数据吞吐的能力。在系统设计方面,我们通过减少不必要的信息提交量等方法来提高系统在特殊情况下的稳定性能。
经过对系统功能的分析,调查,研究,总结出基于Java的班级管理系统主要实现的是对班级信息、班级活动、学生信息、考勤信息、成绩信息、奖惩信息等管理功能。这样,可以对该系统绘制业务流程图。
如下为业务流程图图例。
图3-4业务流程图图例
系统的业务流程如下图所示。
图3-5系统业务流程图
目前B/S体系的系统主要的数据访问方式是:通过浏览器页面用户可以进入系统,系统可以自动对用户向服务器发送的请求进行处理,处理请求是在系统后台中进行的,用户在浏览器页面上进行相应操作,就能够看到服务端传递的处理结果。班级管理系统主要分为视图-模型-控制三层架构设计。在视图层中,主要是操作在服务器端向客户端反馈并显示的数据,在模型层中,主要处理相关的业务逻辑、数据整合等,最后的控制层它介于视图和模型之间,主要是调整两层之间的关系,最终落实数据的传递。
系统架构图如图4-1所示。
图4-1系统架构图
在这个班级管理系统上,我们将会发现一个由两个部门组成的系统。
虽然两个模块看起来各自独立,但它们所使用的数据库却是一致的。这些模块的功能都是经过精心设计和分析,并结合了大量的资料和信息,才得以实现的。
综上所述,系统功能结构图如图4-2所示。
图4-2 系统功能结构图
登录模块:使用基于Java的班级管理系统的实现必须要先在登录页面进行注册,注册之后登录注册账户开始使用本系统。本系统的主要用户分为学生用户、班委用户以及管理员三种,根据用户以及权限的不同,分别打开不同的操作界面。该部分主要利用boot脚本确定网页中CSS样式,从而实现页面的设计,通过调用controller文件进行逻辑判断后,调用dao 层中的方法匹配datab试,集成测试。ase中的数据完成登录操作。当数据库匹配失败时,返回相应提示。注册部分设计与登录类似,只需数据库不存在相同账户信息就可实现注册功能。
该系统包括三个主要模块:浏览、检索和维护。管理员拥有维护这些信息的权限,并能够发布最新的班级信息和班级活动信息、学生信息、考勤信息、成绩信息、奖惩信息和更新已有的信息。
学生用户模块:
(1)首页信息:班级管理系统的首页信息包含了首页、公告消息、校园资讯、班级信息、班级活动、我的账户、个人中心(个人首页、学生信息、考勤信息、成绩信息、奖惩信息、收藏)等。
(2)用户注册:用户点击“注册”按钮,并输入账号,设置密码,确认密码,昵称,邮箱,选择身份,点击“立即注册”按钮进行注册。
(3)用户登录:点击“登录”按钮,输入用户名,密码和验证码进行登录。
(4)密码修改:用户使用该系统注册完成后,用户对登录密码有修改需求时,系统也可以提供用户修改密码权限。系统中所有的操作者能够变更自己的密码信息,执行该功能首先必须要登入系统,然后选择密码变更选项以后在给定的文本框中填写初始密码和新密码来完成修改密码的操作。在填写的时候,假如两次密码填写存在差异,那么此次密码变更操作失败。
(5)我的账户:在前台点击“我的账户”可以对个人资料+密码修改进行管控。
(6)网站公告:用户进行网站公告的阅览,查看管理者发布的行网站公告信息。
(7)班级信息:学生用户可以查看、收藏、评论班级信息。
(8)班级活动:用户可以查看、收藏、评论班级活动。
(9)学生信息:在首页点击“个人中心”按钮进入个人首页,点击“学生信息”按钮,可以输入关键词进行查询学生信息,可以进行查看详情、重置等操作。
(10)考勤信息:在首页点击“个人中心”按钮进入个人首页,点击“考勤信息”按钮,可以输入关键词进行查询考勤信息,可以进行查看详情、重置等操作。
(11)校园资讯:在首页点击“校园资讯”按钮进入校园资讯列表,可以输入关键词进行查询校园资讯信息,并且可以对查看的校园资讯进行评论、收藏、点赞操作。
(12)成绩信息:在首页点击“个人中心”按钮进入个人首页,点击“成绩信息”按钮,可以输入关键词进行查询成绩信息,可以进行查看详情、重置等操作。
(13)奖惩信息:在首页点击“个人中心”按钮进入个人首页,点击“奖惩信息”按钮,可以输入关键词进行查询奖惩信息,可以进行查看详情、重置等操作。
后台管理员管理模块:
(1)管理员登录:管理员在后台可以输入用户名+密码进行登录,管理员的用户名和密码是在数据库中直接设定好的。
(2)管理员功能界面:管理员可以查看后台首页、系统用户(管理员、班委用户、学生用户)、班级信息管理(班级信息列表、班级信息添加)、班级活动管理、学生信息管理、考勤信息管理、成绩信息管理、奖惩信息管理、系统管理、公告信息管理、资源管理等,并且可以根据需要进行相应的操作。
(3)系统用户管理:管理员可以对班级管理系统中的管理员,学生用户、班委用户进行增删改查。
(4)系统管理:点击“轮播图”可以查看到系统中的轮播图信息,如果想要添加新的轮播图,点击“添加”按钮,根据提示输入上轮播图信息,点击“提交”按钮,信息没有错误的话,添加就完成了,如果轮播图信息有误,可以对轮播图更新维护,也可以直接删除某一轮播图。
(5)公告信息管理:管理员点击“公告信息”按钮,可查看通知公告,如需添加新的通知公告,点击下侧“添加”按钮,并输入标题、正文,点击“提交”按钮进行提交,同时也支持对已有的通知公告进行编辑,删除和查询。
(6)班级信息管理:管理员点击“班级信息管理”会显示班级信息列表、班级信息添加,支持通过关键词进行查询,如果想要添加新的班级信息,点击“班级信息添加”按钮,输入相关信息,点击“提交”按钮就可以添加了,同时可以选择某一条班级信息,点击“删除”进行删除。在班级信息列表,可以进行查看详情、录入学生、发布活动等操作。
(7)资源管理:管理员可以对班级管理系统前台展示的校园资讯以及校园资讯所属的分类进行管控。
(8)班级活动管理:管理员点击“班级活动管理”会显示班级活动列表,支持通过关键词进行查询,管理可对班级活动进行查询、重置、删除等操作。
(9)学生信息管理:管理员点击“学生信息管理”会显示学生信息列表,支持通过关键词进行查询,可以进行查看详情、录入考勤、录入成绩、录入奖惩等操作。
(10)考勤信息管理:管理员点击“考勤信息管理”会显示考勤信息列表,支持通过关键词进行查询,管理可对考勤信息进行查询、重置、删除等操作。
(11)成绩信息管理:管理员点击“成绩信息管理”会显示成绩信息列表,支持通过关键词进行查询,管理可对成绩信息进行查询、重置、删除等操作。
(12)奖惩信息管理:管理员点击“奖惩信息管理”会显示奖惩信息列表,支持通过关键词进行查询,管理可对奖惩信息进行查询、重置、删除等操作。
班委用户管理模块:
班委用户可以在相对应的功能模块录入自己班级的班级信息、学生信息、考勤信息、成绩信息、奖惩信息,并可进行增删改查的操作。
数据库概念设计是指对于某个具体应用的数据模型(数据结构),进行抽象和设计,以便在后续的数据库实现阶段中进行数据库逻辑设计和物理结构设计。概念结构本身特性就是其能表现来自用户的各类需求。
系统ER图如图4-3所示。
图4-3 系统ER图
基于Java的班级管理系统的实现所拥有的数据表有以下:用户信息表,班级信息表,班级活动信息表,学生信息表等。
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | token_id | int | 10 | 0 | N | Y | 临时访问牌ID | |
2 | token | varchar | 64 | 0 | Y | N | 临时访问牌 | |
3 | info | text | 65535 | 0 | Y | N | ||
4 | maxage | int | 10 | 0 | N | N | 2 | 最大寿命:默认2小时 |
5 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
6 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
7 | user_id | int | 10 | 0 | N | N | 0 | 用户编号: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | article_id | mediumint | 8 | 0 | N | Y | 文章id:[0,8388607] | |
2 | title | varchar | 125 | 0 | N | Y | 标题:[0,125]用于文章和html的title标签中 | |
3 | type | varchar | 64 | 0 | N | N | 0 | 文章分类:[0,1000]用来搜索指定类型的文章 |
4 | hits | int | 10 | 0 | N | N | 0 | 点击数:[0,1000000000]访问这篇文章的人次 |
5 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
6 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
7 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
8 | source | varchar | 255 | 0 | Y | N | 来源:[0,255]文章的出处 | |
9 | url | varchar | 255 | 0 | Y | N | 来源地址:[0,255]用于跳转到发布该文章的网站 | |
10 | tag | varchar | 255 | 0 | Y | N | 标签:[0,255]用于标注文章所属相关内容,多个标签用空格隔开 | |
11 | content | longtext | 2147483647 | 0 | Y | N | 正文:文章的主体内容 | |
12 | img | varchar | 255 | 0 | Y | N | 封面图 | |
13 | description | text | 65535 | 0 | Y | N | 文章描述 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | type_id | smallint | 5 | 0 | N | Y | 分类ID:[0,10000] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000]决定分类显示的先后顺序 |
3 | name | varchar | 16 | 0 | N | N | 分类名称:[2,16] | |
4 | father_id | smallint | 5 | 0 | N | N | 0 | 上级分类ID:[0,32767] |
5 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该分类的作用 | |
6 | icon | text | 65535 | 0 | Y | N | 分类图标: | |
7 | url | varchar | 255 | 0 | Y | N | 外链地址:[0,255]如果该分类是跳转到其他网站的情况下,就在该URL上设置 | |
8 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
表attendance_information (考勤信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | attendance_information_id | int | 10 | 0 | N | Y | 考勤信息ID | |
2 | class_name | varchar | 64 | 0 | Y | N | 班级名称 | |
3 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
4 | student_users | int | 10 | 0 | Y | N | 0 | 学生用户 |
5 | student_name | varchar | 64 | 0 | Y | N | 学生姓名 | |
6 | attendance_category | varchar | 64 | 0 | Y | N | 考勤类别 | |
7 | attendance_date | date | 10 | 0 | Y | N | 考勤日期 | |
8 | attendance_frequency | varchar | 64 | 0 | Y | N | 考勤次数 | |
9 | remarks | varchar | 64 | 0 | Y | N | 备注信息 | |
10 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
11 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | auth_id | int | 10 | 0 | N | Y | 授权ID: | |
2 | user_group | varchar | 64 | 0 | Y | N | 用户组: | |
3 | mod_name | varchar | 64 | 0 | Y | N | 模块名: | |
4 | table_name | varchar | 64 | 0 | Y | N | 表名: | |
5 | page_title | varchar | 255 | 0 | Y | N | 页面标题: | |
6 | path | varchar | 255 | 0 | Y | N | 路由路径: | |
7 | position | varchar | 32 | 0 | Y | N | 位置: | |
8 | mode | varchar | 32 | 0 | N | N | _blank | 跳转方式: |
9 | add | tinyint | 3 | 0 | N | N | 1 | 是否可增加: |
10 | del | tinyint | 3 | 0 | N | N | 1 | 是否可删除: |
11 | set | tinyint | 3 | 0 | N | N | 1 | 是否可修改: |
12 | get | tinyint | 3 | 0 | N | N | 1 | 是否可查看: |
13 | field_add | text | 65535 | 0 | Y | N | 添加字段: | |
14 | field_set | text | 65535 | 0 | Y | N | 修改字段: | |
15 | field_get | text | 65535 | 0 | Y | N | 查询字段: | |
16 | table_nav_name | varchar | 500 | 0 | Y | N | 跨表导航名称: | |
17 | table_nav | varchar | 500 | 0 | Y | N | 跨表导航: | |
18 | option | text | 65535 | 0 | Y | N | 配置: | |
19 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
20 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | class_activities_id | int | 10 | 0 | N | Y | 班级活动ID | |
2 | class_name | varchar | 64 | 0 | Y | N | 班级名称 | |
3 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
4 | activity_name | varchar | 64 | 0 | Y | N | 活动名称 | |
5 | activity_category | varchar | 64 | 0 | Y | N | 活动类别 | |
6 | activity_time | datetime | 19 | 0 | Y | N | 活动时间 | |
7 | event_cover | varchar | 255 | 0 | Y | N | 活动封面 | |
8 | event_introduction | longtext | 2147483647 | 0 | Y | N | 活动简介 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | class_committee_users_id | int | 10 | 0 | N | Y | 班委用户ID | |
2 | name_of_class_committee_member | varchar | 64 | 0 | Y | N | 班委姓名 | |
3 | gender_of_class_committee_member | varchar | 64 | 0 | Y | N | 班委性别 | |
4 | age_of_class_committee_member | varchar | 64 | 0 | Y | N | 班委年龄 | |
5 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
6 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | class_information_id | int | 10 | 0 | N | Y | 班级信息ID | |
2 | class_name | varchar | 64 | 0 | N | N | 班级名称 | |
3 | class_size | int | 10 | 0 | Y | N | 0 | 班级人数 |
4 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
5 | class_image | varchar | 255 | 0 | Y | N | 班级图片 | |
6 | class_introduction | longtext | 2147483647 | 0 | Y | N | 班级简介 | |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | collect_id | int | 10 | 0 | N | Y | 收藏ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 收藏人ID: |
3 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
4 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
5 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
6 | title | varchar | 255 | 0 | Y | N | 标题: | |
7 | img | varchar | 255 | 0 | Y | N | 封面: | |
8 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | comment_id | int | 10 | 0 | N | Y | 评论ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 评论人ID: |
3 | reply_to_id | int | 10 | 0 | N | N | 0 | 回复评论ID:空为0 |
4 | content | longtext | 2147483647 | 0 | Y | N | 内容: | |
5 | nickname | varchar | 255 | 0 | Y | N | 昵称: | |
6 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
9 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
10 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
11 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | grade_information_id | int | 10 | 0 | N | Y | 成绩信息ID | |
2 | class_name | varchar | 64 | 0 | Y | N | 班级名称 | |
3 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
4 | student_users | int | 10 | 0 | Y | N | 0 | 学生用户 |
5 | student_name | varchar | 64 | 0 | Y | N | 学生姓名 | |
6 | grades_subject | varchar | 64 | 0 | Y | N | 成绩科目 | |
7 | grade_score | int | 10 | 0 | Y | N | 0 | 成绩分数 |
8 | input_time | date | 10 | 0 | Y | N | 录入时间 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | hits_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | notice_id | mediumint | 8 | 0 | N | Y | 公告id: | |
2 | title | varchar | 125 | 0 | N | N | 标题: | |
3 | content | longtext | 2147483647 | 0 | Y | N | 正文: | |
4 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
5 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | praise_id | int | 10 | 0 | N | Y | 点赞ID: | |
2 | user_id | int | 10 | 0 | N | N | 0 | 点赞人: |
3 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | status | bit | 1 | 0 | N | N | 1 | 点赞状态:1为点赞,0已取消 |
表reward_and_punishment_information (奖惩信息)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | reward_and_punishment_information_id | int | 10 | 0 | N | Y | 奖惩信息ID | |
2 | class_name | varchar | 64 | 0 | Y | N | 班级名称 | |
3 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
4 | student_users | int | 10 | 0 | Y | N | 0 | 学生用户 |
5 | student_name | varchar | 64 | 0 | Y | N | 学生姓名 | |
6 | category_of_rewards_and_punishments | varchar | 64 | 0 | Y | N | 奖惩类别 | |
7 | reward_and_punishment_time | date | 10 | 0 | Y | N | 奖惩时间 | |
8 | reward_and_punishment_content | text | 65535 | 0 | Y | N | 奖惩内容 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | sensitive_vocabulary_id | int | 10 | 0 | N | Y | 敏感词汇ID | |
2 | sensitive_vocabulary | varchar | 64 | 0 | Y | N | 敏感词汇 | |
3 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
4 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | slides_id | int | 10 | 0 | N | Y | 轮播图ID: | |
2 | title | varchar | 64 | 0 | Y | N | 标题: | |
3 | content | varchar | 255 | 0 | Y | N | 内容: | |
4 | url | varchar | 255 | 0 | Y | N | 链接: | |
5 | img | varchar | 255 | 0 | Y | N | 轮播图: | |
6 | hits | int | 10 | 0 | N | N | 0 | 点击量: |
7 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | student_information_id | int | 10 | 0 | N | Y | 学生信息ID | |
2 | class_name | varchar | 64 | 0 | Y | N | 班级名称 | |
3 | class_committee_users | int | 10 | 0 | Y | N | 0 | 班委用户 |
4 | student_users | int | 10 | 0 | Y | N | 0 | 学生用户 |
5 | student_name | varchar | 64 | 0 | Y | N | 学生姓名 | |
6 | enter_the_number_of_people | varchar | 64 | 0 | Y | N | 录入人数 | |
7 | enter_date | date | 10 | 0 | Y | N | 录入日期 | |
8 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | student_users_id | int | 10 | 0 | N | Y | 学生用户ID | |
2 | student_name | varchar | 64 | 0 | Y | N | 学生姓名 | |
3 | student_gender | varchar | 64 | 0 | Y | N | 学生性别 | |
4 | student_age | varchar | 64 | 0 | Y | N | 学生年龄 | |
5 | examine_state | varchar | 16 | 0 | N | N | 已通过 | 审核状态 |
6 | user_id | int | 10 | 0 | N | N | 0 | 用户ID |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | upload_id | int | 10 | 0 | N | Y | 上传ID | |
2 | name | varchar | 64 | 0 | Y | N | 文件名 | |
3 | path | varchar | 255 | 0 | Y | N | 访问路径 | |
4 | file | varchar | 255 | 0 | Y | N | 文件路径 | |
5 | display | varchar | 255 | 0 | Y | N | 显示顺序 | |
6 | father_id | int | 10 | 0 | Y | N | 0 | 父级ID |
7 | dir | varchar | 255 | 0 | Y | N | 文件夹 | |
8 | type | varchar | 32 | 0 | Y | N | 文件类型 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | user_id | mediumint | 8 | 0 | N | Y | 用户ID:[0,8388607]用户获取其他与用户相关的数据 | |
2 | state | smallint | 5 | 0 | N | N | 1 | 账户状态:[0,10](1可用|2异常|3已冻结|4已注销) |
3 | user_group | varchar | 32 | 0 | Y | N | 所在用户组:[0,32767]决定用户身份和权限 | |
4 | login_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 上次登录时间: |
5 | phone | varchar | 11 | 0 | Y | N | 手机号码:[0,11]用户的手机号码,用于找回密码时或登录时 | |
6 | phone_state | smallint | 5 | 0 | N | N | 0 | 手机认证:[0,1](0未认证|1审核中|2已认证) |
7 | username | varchar | 16 | 0 | N | N | 用户名:[0,16]用户登录时所用的账户名称 | |
8 | nickname | varchar | 16 | 0 | Y | N | 昵称:[0,16] | |
9 | password | varchar | 64 | 0 | N | N | 密码:[0,32]用户登录所需的密码,由6-16位数字或英文组成 | |
10 | | varchar | 64 | 0 | Y | N | 邮箱:[0,64]用户的邮箱,用于找回密码时或登录时 | |
11 | email_state | smallint | 5 | 0 | N | N | 0 | 邮箱认证:[0,1](0未认证|1审核中|2已认证) |
12 | avatar | varchar | 255 | 0 | Y | N | 头像地址:[0,255] | |
13 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | group_id | mediumint | 8 | 0 | N | Y | 用户组ID:[0,8388607] | |
2 | display | smallint | 5 | 0 | N | N | 100 | 显示顺序:[0,1000] |
3 | name | varchar | 16 | 0 | N | N | 名称:[0,16] | |
4 | description | varchar | 255 | 0 | Y | N | 描述:[0,255]描述该用户组的特点或权限范围 | |
5 | source_table | varchar | 255 | 0 | Y | N | 来源表: | |
6 | source_field | varchar | 255 | 0 | Y | N | 来源字段: | |
7 | source_id | int | 10 | 0 | N | N | 0 | 来源ID: |
8 | register | smallint | 5 | 0 | Y | N | 0 | 注册位置: |
9 | create_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间: |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间: |
在基于Java的班级管理系统的实现中,用户可以通过输入账号、密码和其他信息来完成登录,如图5-1所示。
图5-1登录界面图
在登陆方法中,有一个map类型的参数,用于存储从浏览器中发送过来的数据,方法的返回值也是一个map类型,键值对结构,非空校验通过后会调用service层的一个select方法,该方法主要是格式化生成一个sql查询语句,生成的sql语句会作为参数传给,servece层的另外一个方法,该方法会直接调用dao层的方法操作数据库,而之前生成的sql语句也会作为参数传送过去,登陆使用了MD5加密,登陆成功后,会给登陆成功的用户发送登陆令牌,登陆令牌为实体类,映射到数据库中的AccessToken表,该实体类含有令牌ID,使用UUID工具,创建不重复的字符串作为ID,然后会将用户的信息同样作为属性,加入到令牌对象中,之后执行service的save方法,与用户登陆时查询用户原理一致,会将令牌信息存入到数据库中,之后采用json格式封装返回给浏览器的数据,返回的数据封装好时,调用success方法,格式化返回的数据,以特定的格式返回给浏览器,浏览器写通用的代码,对返回的数据进行验证和处理,登陆代码如下:
@PostMapping("login")
public Map<String, Object> login(@RequestBody Map<String, String> data, HttpServletRequest httpServletRequest) {
log.info("[执行登录接口]");
String username = data.get("username");
String email = data.get("email");
String phone = data.get("phone");
String password = data.get("password");
List resultList = null;
QueryWrapper wrapper = new QueryWrapper<User>();
Map<String, String> map = new HashMap<>();
登陆拦截管理器,在interceptor文件夹下的LoginInterceptor.java文件,拦截器会首先对用户登陆注册的接口放行,之后会对用户登陆的身份令牌进行校验,如果没有身份令牌,为“未登录用户”,无身份令牌的游客依然允许访问,固对请求做了限制,post请求要求必须要有身份令牌,所以在post请求没有身份令牌的情况下,会禁止用户登陆,并禁止用户访问相关的接口,拦截器中,做了跨域处理,代码如下:
@Slf4j
public class LoginInterceptor implements HandlerInterceptor {
private String tokenName = "x-auth-token";
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
String token = request.getHeader(this.tokenName);
setHeader(request, response);
log.info("[请求接口] - {} , [请求类型] - {}",request.getRequestURL().toString(),request.getMethod());
private void setHeader(HttpServletRequest request, HttpServletResponse response) {
response.setHeader("Access-control-Allow-Origin", request.getHeader("Origin"));
response.setHeader("Access-Control-Allow-Methods", "GET, HEAD, POST, PUT, DELETE, TRACE, OPTIONS, PATCH");
response.setHeader("Access-Control-Allow-Credentials", "true");
response.setHeader("Access-Control-Allow-Headers", request.getHeader("Access-Control-Request-Headers"));
response.setHeader("Access-Control-Max-Age", "1800");
response.setHeader("Content-Type", "application/json;charset=UTF-8");
response.setStatus(HttpStatus.OK.value());
}
在首页,学生用户可以轻松访问首页、公告消息、校园资讯、班级信息、班级活动、我的账户、个人中心等多种功能,如图5-2所示,为用户提供了更加便捷的服务。
图5-2系统首页界面图
在校园资讯页面,用户可以轻松获取有关校园资讯的详细信息,还可以通过关键字快速搜索,同时还可以进行点赞、评论、收藏等功能,如图5-3所示。
图5-3校园资讯界面图
班级信息页面可以查看班级信息列表,支持通过关键词搜索班级信息,可点击班级信息查看班级详情。如下图所示。
图5-4班级信息界面图
通过访问个人中心,用户可以查看和管控个人首页、数据分析、学生信息、考勤信息、成绩信息、奖惩信息、收藏等信息,点击“学生信息”按钮,可以查看学生信息表,点击“成绩信息”按钮,可以查看成绩信息表。如下图所示。
图5-5个人首页界面图
图5-6学生信息界面图
图5-7成绩信息界面图
通过访问“我的账户”,用户可以修改头像、昵称、密码等,详见下图。
图5-8我的账户界面图
图5-9修改密码界面图
班级活动页面可以查看班级活动详情信息:班级名称、班级人数、班委用户、活动名称、活动时间、活动类别、活动简介等,可进行收藏、评论等操作。如下图所示。
图5-10班级活动详情界面图
通过管理员功能页面,管理员可以查看后台首页、系统用户(管理员、班委用户、学生用户)、班级信息管理(班级信息列表、班级信息添加)、班级活动管理、学生信息管理、考勤信息管理、成绩信息管理、奖惩信息管理、系统管理、公告信息管理、资源管理等,并且可以根据需要进行相应的操作,如图5-11所示。
图5-11理员功能界面图
管理员可以对系统中所有的用户角色进行管控,包含了管理员、学生用户、班委用户这三种角色,如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以查看到了,可以点击用户后面的“删除”按钮直接删除某一用户。系统用户管理界面如下图所示。
图5-12学生用户管理界面图
用户的权限,存储在实体类entity下的UserGroup.java中,数据库表中,该表格存储的是用户的相应权限,每一个user用户表下的每一条数据,代表一个用户,里面都有一个UserGroup字段,来判断当前所具有的身份和权限,浏览器通过访问UserGroupController.java相应的方法,获取当前用户具有的权限,根据相应的权限定制该用户菜单显示,代码如下:
@TableName("user_group")
@Data
@EqualsAndHashCode(callSuper = false)
public class UserGroup implements Serializable {
private static final long serialVersionUID = 968356951391304707L;
}
管理员可以对系统前台展示的轮播图进行增删改查,方便用户进行查看。轮播图管理界面如下图所示。
图5-13系统管理界面图
项目方法集成在BaseController.java文件中,增的代码如下:
@PostMapping("/add")
@Transactional
public Map<String, Object> add(HttpServletRequest request) throws IOException {
service.insert(service.readBody(request.getReader()));
return success(1);
}
@Transactional
public Map<String, Object> addMap(Map<String,Object> map){
service.insert(map);
return success(1);
}
项目方法集成在BaseController.java文件中,删的代码如下:
@RequestMapping(value = "/del")
@Transactional
public Map<String, Object> del(HttpServletRequest request) {
service.delete(service.readQuery(request), service.readConfig(request));
return success(1);
}
项目方法集成在BaseController.java文件中,改的代码如下:
@PostMapping("/set")
@Transactional
public Map<String, Object> set(HttpServletRequest request) throws IOException {
service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));
return success(1);
}
项目方法集成在BaseController.java文件中,查询一条数据的代码如下:
@RequestMapping("/get_obj")
public Map<String, Object> obj(HttpServletRequest request) {
List resultList = service.selectBaseList(service.select(service.readQuery(request), service.readConfig(request)));
if (resultList.size() > 0) {
JSONObject jsonObject = new JSONObject();
jsonObject.put("obj",resultList.get(0));
return success(jsonObject);
} else {
return success(null);
}
}
项目方法集成在BaseController.java文件中,查询列表数据的代码如下:
@RequestMapping("/get_list")
public Map<String, Object> getList(HttpServletRequest request) {
Map<String, Object> map = service.selectToPage(service.readQuery(request), service.readConfig(request));
return success(map);
}
点击“公告信息管理”这个菜单,可以查看到系统中所有添加的系统公告,支持通过标题对系统公告进行查询,添加、删除等操作。公告信息管理界面如下图所示。
图5-14公告信息管理界面图
当点击“资源管理”这一菜单的时候,会出现校园资讯+资讯分类这两个子菜单,可以对这两个模块进行增删改查操作。资源管理界面如下图所示。
点击“班级信息管理”这个菜单,会出现班级信息列表+班级信息添加这两个子菜单,可以查看班级信息详情,可以点击“录入学生”按钮跳转学生信息录入界面,填写相关信息后点击提交即可完成学生信息录入;可以点击“发布活动”按钮跳转活动信息发布界面,填写相关信息后点击提交即可完成活动信息发布。如下图所示。
图5-16班级信息管理界面图
-
- 班委用户功能模块(后端)
点击“学生信息管理”这个菜单,会出现学生信息列表+学生信息添加这两个子菜单,可以查看学生信息详情,可以点击“录入成绩”按钮跳转成绩信息录入界面,填写相关信息后点击提交即可完成成绩信息录入;可以点击“录入考勤”按钮跳转考勤信息录入界面,填写相关信息后点击提交即可完成考勤信息录入;可以点击“录入奖惩”按钮跳转奖惩信息录入界面,填写相关信息后点击提交即可完成奖惩信息录入;。如下图所示。
图5-18成绩信息录入界面图
图5-19奖惩信息录入界面图
图5-20考勤信息录入界面图
无论什么样的系统,测试都至关重要,因为它们可以帮助我们检查出潜藏的缺陷,从而确保它们的性能和稳定性,避免Bug的出现,并确保它们的功能和性价比达到预期的要求。为了确保系统的安全、高效、可靠,我们将采取三种不同的方法:单元、功能、及AP的检验。
表6-1展示了一个系统登录功能的测试用例,它可以检测用户名和密码的输入,并且可以观察到系统的反应,从而证明这个功能已经达到了预期的效果。
表6-1 系统登录功能测试用例
功能描述 | 用于系统登录 | |
测试目的 | 检测登录时的合法性检查 | |
测试数据以及操作 | 预期结果 | 实际结果 |
输入的用户名和密码带有非法字符 | 提示用户名或者密码错误 | 与预期结果一致 |
输入的用户名或者密码为空 | 提示用户名或者密码错误 | 与预期结果一致 |
输入的用户名和密码不存在 | 提示用户名或者密码错误 | 与预期结果一致 |
输入正确的用户名和密码 | 登录成功 | 与预期结果一致 |
表6-2提供了一个详细的注册功能测试用例,它可以有效地检测各种数据的输入,并且可以观察系统的反应,从而证明该功能已经达到了预期的目标。
表6-2 注册功能测试用例
功能描述 | 用于用户注册 | |
测试目的 | 检测用户注册时的合法性检查 | |
测试数据以及操作 | 预期结果 | 实际结果 |
输入的手机号不合法 | 提示请输入正确的手机号码 | 与预期结果一致 |
输入的字段为空 | 提示必填项不能为空 | 与预期结果一致 |
输入的密码少于6位 | 提示密码必须为6-12位 | 与预期结果一致 |
输入的密码大于12位 | 提示密码必须为6-12位 | 与预期结果一致 |
通过使用表6-3的测试,我们可以看到,在进行班级信息管理时,我们可以进行增、减、更新和查询等操作,并且这些操作都已经被成功地执行。通过观察系统的反馈,我们发现这项功能已经实现了我们的预期,并且运行良好。
前置条件;用户登录系统。
表6-3 班级信息管理的测试用例
功能描述 | 用于班级信息管理 | |
测试目的 | 检测班级信息管理时的各种操作的运行情况 | |
测试数据以及操作 | 预期结果 | 实际结果 |
点击添加班级信息,必填项合法输入,点击保存 | 提示添加成功 | 与预期结果一致 |
点击添加班级信息,必填项输入不合法,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击修改班级信息,必填项修改为空,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击修改班级信息,必填项输入不合法,点击保存 | 提示必填项不能为空 | 与预期结果一致 |
点击删除班级信息,选择职位删除 | 提示删除成功 | 与预期结果一致 |
点击搜索班级信息,输入存在的班级信息名 | 查找出服务类型 | 与预期结果一致 |
点击搜索班级信息,输入不存在的班级信息名 | 不显示服务类型 | 与预期结果一致 |
系统评价是指在系统完成或改建后,根据预定的系统目标或现有成绩,从技术、经济、社会、功能等方面进行的评价或审核。本系统个人初步评价如下。
(1)系统功能评价:
根据需求分析以及测试结果来看,本系统已将达到了初期的需求目标,满足了用户对应需求。
(2)系统技术评价:
本系统设计略显繁杂,开发过程中对功能进行了一定的简化,运行时较为稳定,暂未发现安全问题。
(3)系统经济评价:
系统在低成本开发的基础上达到了设计要求。预计可以为用户节省一定的人力、物力。
随着科技的飞速发展,越来越多的行业和企业都在利用计算机技术来管理日益增长的数据。本文旨在探讨基于Java的班级管理系统的实现,以满足班级管理的需求。
本次毕业论文主要是利用SSM+Vue开发一个安全可靠,操作简易,同时具备业务可扩展的班级管理系统。本文详细的论述了小程序的设计和开发,本系统的所有事务逻辑都是按照系统的需求分析进行设计的,系统有学生用户、班委用户和系统管理员三种角色,本系统多处采用了Ajax的异步交互技术,同时它也叫异步交互技术,利用它我们可以让网页的局部进行数据刷新操作,Ajax和传统的数据更新技术大大增加了客户的体验程度,由于是对局部进行操作那么就减少了一些繁琐而又不必要的操作,减轻了服务器对页面解析的负担。
目前完成的基于Java的班级管理系统,还有许多有待改进的地方。一个是功能上的改进,第二个是技术上的改进。另外,系统如果能提供更多的功能就会使得系统更加丰富和多样化,比如兼职数据分析和可视化等。另外就是对前端UI的使用还不够熟练,视觉效果和界面观感有待提升,希望日后能对这个系统有所改进。
参考文献
[1]刘小丹.C++与Java程序设计语言的特征研究[J].电脑编程技巧与维护,2023,(10):52-54.DOI:10.16184/j.cnki.comprg.2023.10.001
[2]刘佳乐,赵雨,厚露露等.基于Java Web的学生信息管理系统[J].现代信息科技,2023,7(19):21-24.DOI:10.19850/j.cnki.2096-4706.2023.19.005
[3]尹应荆.JAVA编程语言在计算机软件开发中的应用[J].石河子科技,2023,(05):45-47.
[4]袁琳琳.浅析Java语言在计算机软件开发中的应用[J].信息记录材料,2023,24(09):81-83.DOI:10.16009/j.cnki.cn13-1295/tq.2023.09.006
[5]闫立誉.基于Java平台开发的软件保护技术探究[J].数字技术与应用,2023,41(08):199-201.DOI:10.19695/j.cnki.cn12-1369.2023.08.63
[6]Surya H I P ,Imam B ,Wiwandari H .Land use change and precipitation implication to hydro-meteorological disasters in Central Java: an overview[J].International Journal of Disaster Resilience in the Built Environment,2023,14(1):100-114.
[7]Larsen S ,Falleri J ,Baudry B , et al.Spork: Structured Merge for Java With Formatting Preservation[J].IEEE Transactions on Software Engineering,2023,49(1):64-83.
[8]D N ,AE P ,I L , et al.Land cover changes and spatial planning alignment in East Java Province[J].IOP Conference Series: Earth and Environmental Science,2023,1133(1):
[9]Maria W ,Budi Y H .The effect of financial literacy and social media on micro capital through financial technology in the creative industry sector in East Java[J].Cogent Economics Finance,2022,10(1):
[10]刘思云,陈贵松.地方高校班级管理系统的设计与实现[J].现代计算机,2022,28(19):116-120.
[11]秦望.班级管理系统与系统管理[J].河南教育(基教版),2022,(04):33-35.
[12]张子瑜.一种基于Android的班级信息管理系统设计与实现[J].电脑编程技巧与维护,2020,(11):63-65.DOI:10.16184/j.cnki.comprg.2020.11.022
[13]郝东晓.高校班级管理信息化平台建设探究[J].数码世界,2020,(11):235-236.
[14]邓志龙.基于Spring MVC架构的高职院校班级管理系统设计与实现[J].教育观察,2020,9(18):79-80.DOI:10.16070/j.cnki.cn45-1388/g4s.2020.18.031
[15]梁相栋,郭小燕,许亮等.班级文化信息管理系统的建设与开发[J].甘肃科技,2020,36(04):25-27+39.
[16]陆旻明,点心班级管理系统[简称:班级管理系统]V4.0.安徽省,安徽点心文化传媒有限公司,2020-01-09.
[17]孙红艳.基于SSH框架的班级事物管理系统设计与实现[J].电脑编程技巧与维护,2019,(12):135-136+139.DOI:10.16184/j.cnki.comprg.2019.12.050
[18]谢雨初,刘文龙,姚懿等.基于B/S模式的大学生综合测评管理系统的设计与实现[J].电脑与信息技术,2019,27(04):79-82.DOI:10.19414/j.cnki.1005-1228.2019.04.023
[19]倪红,钱雨,汤力.浅谈信息技术助力下的职校班级现代化管理[J].当代教育实践与教学研究,2019,(12):3-4+8.DOI:10.16534/j.cnki.cn13-9000/g.2019.1304
[20]邝家旺,孙蕾,王晓飞.新时代高校“互联网+班级”管理新模式构建及优越性探析[J].教育现代化,2019,6(34):208-209+213.DOI:10.16541/j.cnki.2095-8420.2019.34.082
致 谢
在这3个月的毕业设计过程中,指导教师的指导发挥了至关重要的作用,他们的认真负责的工作态度、谨慎的教学精神以及丰富的理论知识,为我的设计提供了强有力的支持,使得整个过程顺利进行。她的教学方式非常认真,让我印象深刻。我从她那里学到了很多知识,并在实践中不断提升。我对这位老师表示由衷的感谢。
经过对毕业设计的全面研究和开发,我的系统取得了重大突破,从需求分析到实现复杂功能,再到最终的测试和维护,使我对系统有了更加深刻的理解。此外,我还在实践中不断提升自己的技能,解决复杂问题,这是这次毕业设计最大的收获。
最终,在整个系统开发的过程中,我的同学和朋友们给予了我极大的帮助,他们的建议让我能够迅速地确定系统的商业理念。因此,我深深地感谢他们的支持。