SSM德庆县乡村教育图书管理系统
摘 要
大数据时代下,数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求,利用互联网服务于其他行业,促进生产,已经是成为一种势不可挡的趋势。在德庆县乡村教育图书管理的要求下,开发一款整体式结构的德庆县乡村教育图书管理系统,将复杂的系统进行拆分,能够实现对需求的变化快速响应、系统稳定性的保障,能保证平台可持续、规模化发展的要求。
系统开发是采用java语言,基于MVVM模式进行开发,采取MySQL作为后台数据的主要存储单元,采用SSM框架实现了本系统的全部功能。德庆县乡村教育图书管理系统解决了传统管理方式所带来的人力、物力和时间上的虚耗和交流深度的限定,这让交流的过程更快捷、准确、便利,同时完成德庆县乡村教育图书管理系统的基本功能:书籍管理、用户注册管理、预订记录管理、借书还书管理、书籍捐赠管理。
关键词:图书管理;整体式结构;Mysql数据库
SSM Deqing County Rural Education Book Management System
Abstract
In the age of big data, data is growing explosively. In order to meet the trend of the information age and the requirements of information security, it has become an irresistible trend to use the Internet to serve other industries and promote production. Under the requirements of rural education book management in Deqing County, a rural education book management system in Deqing County with an integrated structure is developed to split the complex system, which can achieve rapid response to changes in demand, guarantee the stability of the system, and ensure the sustainable and large-scale development of the platform.
The system is developed based on MVVM mode using Java language, MySQL as the main storage unit of background data, and SSM framework to achieve all the functions of the system. The rural education book management system of Deqing County has solved the waste of manpower, material resources and time brought about by the traditional management method and the limit of communication depth, which makes the communication process more rapid, accurate and convenient. At the same time, it has completed the basic functions of the rural education book management system of Deqing County: book management, user registration management, reservation record management, book borrowing and returning management, book donation management.
Key words:Library management; Integral structure; Mysql database
目 录
第1章 绪论
1.1 研究背景与意义
1.2 论文组成结构
第2章 开发工具及相关技术介绍
2.1 J2EE技术
2.2 MVVM模式
2.3 MySQL数据库
2.4 B/S结构
2.5 SSM框架
2.6 ssm框架各层关系
第3章 系统分析
3.1 可行性分析
3.1.1 技术可行性
3.1.2 经济可行性
3.1.3 操作可行性
3.2 需求分析
3.3 系统业务流程分析
3.4 系统数据流程分析
第4章 系统设计
4.1 系统架构设计
4.2 系统功能结构
4.3 功能模块设计
4.4 数据库设计
4.4.1 概念模型设计
4.4.2 逻辑结构设计
4.4.3 数据库连接设计
第5章 系统实现
5.1 登录模块的实现
5.2 用户子系统模块的实现
5.3 管理员子系统模块的实现
第6章 系统测试
6.1 测试目的
6.2 测试用例
6.2.1 登录测试
6.2.2 注册测试
6.2.3 书籍管理测试
6.2.4 书籍预订测试
6.3 测试结果
第7章 总结与展望
参考文献
致谢
中国是一个农业大国,农村人口居多,为了提高农村教育水平,实现农村义务教育的全覆盖,促进农村经济发展,中国乡村教育管理模式一直以县、乡、村分级管理,这种教育管理模式极大地满足了农村教育水平,也积极促进了农村义务教育,对农村教育管理起到了积极的作用。但是近年来,中国农村经济迅速发展,城镇化水平加速,对农村教育管理提出了新的挑战,农村教育管理面对新的新形势下如何改革和创新教育管理,成为当下农村教育改革亟待解决的一个问题。发展乡村教育是实施乡村振兴的内在要求,也是构建美好乡村生活的出发点。乡村教育在中国全面教育中占有重要的比重,做好乡村教育有助于提升中国的整体教育质量。
德庆县乡村教育德庆县乡村教育图书管理系统充分利用网络的便利性,可以不受时空的局限,对图书进行随时随地的管理,这个系统的开发很大程度地把图书的管理流程简化了,同时也减轻了图书管理人员的工作量,也提高了图书的利用率,还为图书购买者提供了一个便利的捷径。本系统主要的优点体现在下面的几个方面:
(1)管理员通过数据库管理和维护系统可以对借阅者和图书进行管理和维护。管理员可以对后台数据中的信息进行删除、修改、更新等基本操作以管理和维护借阅者信息。
(2)用户可以通过图书的名称、图书编号、作者、图书类型、出版社进行查询,以方便用户对图书信息的快速检索。
(3)图书的添加,新书的出版可以及时的输入数据库以待取用,已经报废的旧书及时的删除或禁用。
(4)图书订单信息,订单信息的录入管理。
根据市场调研得到的信息数据,结合国内外前沿研究,利用相关系统开发和设计方法,最终设计出德庆县乡村教育图书管理系统。
本文共有七章,如下所示。
第一章概述了德庆县乡村教育图书管理系统的研究目的和意义;精炼地总结了国内外在仓储领域的研究情况和未来的研究趋势,最后给出了论文的组成结构。
第二章简要概述了本文所用的开发技术和工具。
第三章简要对系统各业务流程进行需求分析、可行性分析。
第四章对德庆县乡村教育图书管理系统进行设计。
第五章对德庆县乡村教育图书管理系统进行实现,并贴出相关页面截图,语言描述出具体功能实现的操作方法。
第六章对德庆县乡村教育图书管理系统采用测试用例的方式来对一些主要功能模块测试,最后得出测试结果。
第七章总结全文并对未来的研究做出展望。
本系统前端部分基于MVVM模式进行开发,采用B/S模式,后端部分基于Java的ssm框架进行开发。
前端部分:前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库使页面快速成型,项目前端通过栅格布局实现响应式,可适应PC端、平板端、手机端等不同屏幕大小尺寸的完美布局展示。
后端部分:采用ssm作为开发框架,同时集成MyBatis、Redis等相关技术。
MVVM是Model-View-ViewModel的简写。它本质上就是MVC 的改进版。MVVM 就是将其中的View 的状态和行为抽象化,让我们将视图 UI 和业务逻辑分开。当然这些事 ViewModel 已经帮我们做了,它可以取出 Model 的数据同时帮忙处理 View 中由于需要展示内容而涉及的业务逻辑。微软的WPF带来了新的技术体验,如Silverlight、音频、视频、3D、动画……,这导致了软件UI层更加细节化、可定制化。同时,在技术层面,WPF也带来了 诸如Binding、Dependency Property、Routed Events、Command、DataTemplate、ControlTemplate等新特性。MVVM(Model-View-ViewModel)框架的由来便是MVP(Model-View-Presenter)模式与WPF结合的应用方式时发展演变过来的一种新型架构框架。它立足于原有MVP框架并且把WPF的新特性糅合进去,以应对客户日益复杂的需求变化。
Mysql 经过多次的更新,功能层面已经非常的丰富和完善了,从Mysql4版本到5版本进行了比较大的更新,在商业的实际使用中取得了很好的实际应用效果。最新版本的Mysql支持对信息的压缩,同时还能进行加密能更好的满足对信息安全性的需求。同时经过系统的多次更新,数据库自身的镜像功能也得到了很大的增强,运行的流畅度和易用性方面有了不小的进步,驱动的使用和创建也更加的高效快捷。最大的变动还是进行了空间信息的显示优化,能更加方便的在应用地图上进行坐标的标注和运算。强大的备份功能也保证了用户使用的过程会更加安心,同时支持的Office特性还支持用户的自行安装和使用。在信息的显示形式上也进行了不小的更新,增加了两个非常使用的显示区,一个是信息区,对表格和文字进行了分类处理,界面的显示更加清爽和具体。第二是仪表的信息控件,能在仪表信息区进行信息的显示,同时还能进行多个信息的比对,为用户的实际使用带来了很大的便捷。
针对本文中设计的德庆县乡村教育图书管理系统在实际的实现过程中,最终选择Mysql数据库的主要原因在于在企业的应用系统应用及开发的过程中会存在大量的数据库比较频繁的操作,而且数据的安全性要求也是非常的高。综合这些因素,最终选择安全性系数比较高的Mysql来对德庆县乡村教育图书管理系统后台数据进行存储操作。
数据库管理系统的总体结构图如下图所示。
图2-1 数据库组成结构
-
B/S结构
B/S(Browser/Server)比前身架构更为省事的架构。它借助Web server完成数据的传递交流。只需要下载浏览器作为客户端,那么工作就达到“瘦身”效果, 不需要考虑不停装软件的问题。
SSM即SpringMVVM+Spring+MySQL,这三个框架有各自最独有的优势,那么将它们组合在一起能够碰撞出很强的火花。设计者在不需消耗大量功夫,能做出Web应用程序,而且这个程序还具有层次清晰、升级更新操作不影响正常使用的、允许多次使用的特点。这个复合框架形成一个有着结构完整、功能强大和结构良好的体系:SpringMVVM使各板块分离,Spring使开发更灵活方便,让开发者直接对对象进行操纵,各层次分工明细,并实现各个层次间的解耦,让代码更加的灵活精简。这个框架使程序员能够规避在开发时期避免个别错误导致整体被破坏,也能在后期应对客户对产品提出的新需求。
-
- ssm框架各层关系:
DAO层、Service层这两个层次都可以单独开发,互相的耦合度很低,完全可以独立进行,这样的一种模式在开发大项目的过程中尤其有优势。
Controller,View层因为耦合度比较高,因而要结合在一起开发,但是也可以看作一个整体独立于前两个层进行开发。这样,在层与层之前只需要知道接口的定义,调用接口即可完成所需要的逻辑单元应用,一切显得非常清晰简单。
在软件开发的过程中系统的可行性分析是必不可少的,可行性的研究就是评估问题是否能得到解决并且是要以最少的时间和最少的代价来解决。为实现上面的目标还要必须考虑到解决这些问题的方法的优点和缺点,还要考虑到实现了这些系统规模的开发带来的经济效益。这里可以用技术的可行性,操作的可行性,经济的可行性对我们的系统进行可行性的研究。德庆县乡村教育图书管理系统的可行性分析如下所示:
德庆县乡村教育图书管理系统采用的是Java编程语言并于SSM框架,数据库部分采用的是当前流行的MYSQL数据库,德庆县乡村教育图书管理系统中的所有数据资源都存储在Mysql数据库中,不仅减少了服务器对页面的解析而且极大增加了用户的体验度。
德庆县乡村教育图书管理系统是在Mysql的环境中运行的,而系统的成本也只是主要分布在软件的开发和维护上。但如果系统上线投入使用之后,不仅可以方便人们,还节省了用户的时间和精力,而且还极大限度的方便了运营者,减少了运营者的工作强度。德庆县乡村教育图书管理系统其实也不太复杂,在开发的时候经济支出也不大,在开发系统时时间用的也不多,从时间的优势和对经济利益方面产生的好处远超过维护和管理的成本,所以开发此系统是可行合适的。
本系统是基于浏览器和服务器的德庆县乡村教育图书管理系统,系统开发完成之后用户只需要在浏览器中输入正确的URL地址即可进行访问。本系统的前台页面简单明了,在没有操作指导的情况下也可以进行操作,无论是系统管理员还是普通用户在页面中所有的操作都是在浏览器中完成的,因此只要电脑在有网络的情况下,打开浏览器都能操作。而且在使用之前也不用进行相关的环境配置,因此本系统方便、简单、易于使用,所以该系统是容易并且可操作的。
根据用户对系统的需求,要求系统简单操作,能够准确,完整的对信息进行管理。德庆县乡村教育图书管理系统在对需求做解析后,整个系统主要分为两个部分:管理员和普通用户,每个模块下的分支功能不一样。对功能做出如下说明:
管理员模块:系统用户管理、书籍信息管理、书籍类型管理、借书还书管理、预订记录管理、取消预订管理、书籍捐赠管理。
用户模块:图书资讯、书籍信息、书籍捐赠、书籍预订、取消预订、借书还书等。
系统用例图如下所示。
图3-1系统用例图
根据用例图,对一些重要的用例进行描述。
注册用例描述如下表所示。
表3-1 注册用例描述
用例名称 | 注册 |
参与者 | 用户 |
描述 | 用户填写相关信息完成注册成为系统的用户 |
前置条件 | 无 |
后置条件 | 用户填写相关信息并用户账号可用 |
事件流 |
|
补充说明 |
|
登录用例描述如下表所示。
表3-1 登录用例描述
用例名称 | 登录 |
参与者 | 用户 |
描述 | 用户填写用户名和密码登录系统 |
前置条件 | 用户已注册 |
后置条件 | 用户名和密码正确 |
事件流 | (1)用户在登录页面输入用户名和密码 (2)系统检测用户输入的用户名和密码 (3)显示登录成功并返回主页面 |
补充说明 | (a)系统检查除密码不正确,返回登录页面 |
个人信息管理用例描述如下表所示。
表3-1 个人信息管理用例描述
用例名称 | 管理个人信息 |
参与者 | 用户 |
描述 | 用户查看、修改个人信息 |
前置条件 | 用户已登录 |
后置条件 | 无 |
事件流 | (1)用户查看个人信息 (2)用户修改个人信息 |
补充说明 | (a)用户可修改密码 (b)用户可修改联系方式 |
图书出借用例描述如下表所示。
表3-1 图书出借用例描述
用例名称 | 图书出借 |
参与者 | 用户 |
描述 | 用户执行图书出借操作 |
前置条件 | 用户已登录 |
后置条件 | 该图书存在,并且能被借出 |
事件流 | (1)在图书页点击要借的图书 (2)填写图书出借数据 |
补充说明 | (a)图书出借表单数据不能为空 |
图书归还用例描述如下表所示。
表3-1 图书归还用例描述
用例名称 | 图书归还 |
参与者 | 用户 |
描述 | 用户执行图书归还操作 |
前置条件 | 用户已登录 |
后置条件 | 该图书存在,并且能被归还 |
事件流 | (1)在图书页点击要归还的图书 (2)填写图书归还数据 |
补充说明 | (a)图书归还表单数据不能为空 |
书籍用例描述如下表所示。
表3-1 书籍用例描述
用例名称 | 书籍管理 |
参与者 | 管理员 |
描述 | 管理员提供新增、修改、删除书籍等功能 |
前置条件 |
|
后置条件 | 无 |
事件流 | (1)管理员查看修改书籍 (2)管理员添加书籍 (3)管理员删除书籍 |
补充说明 | (a)新添加的书籍不符合要求时会添加失败 (b)修改的书籍不符合要求时会修改失败 |
德庆县乡村教育图书管理系统的业务流程如下图所示。
图3-3 系统业务流程图
管理员拥有最高权限,在对各项信息进行增加、删除、修改后会更新后台数据库的内容,用户在登录进行书籍查看、书籍分类、书籍预订管理、书籍捐赠、图书借出、图书归还录入操作等指令动作同样会更新后台数据。
与强调控制逻辑的程序流程图不同,它更关心的是整个系统中数据的具体流动以及数据的加工处理的整个客观过程,是对数据规格的说明。也正因如此,系统数据流图作为系统结构化分析方法中极为重要的一种描述工具备受青睐。
德庆县乡村教育图书管理系统的系统原理图如下图所示。
图3-4系统原理图
外部实体为用户,第一个流程为登录验证,用户信息表返回密码验证,是否正确,正确则登录系统,错误则反馈信息,登录系统后,根据不同用户的功能选择,来读写数据库。
系统底层数据流如下图所示。
图3-5系统底层数据流图
系统底层数据流:外部实体为管理员和用户,数据流分别有管理员和用户流向系统数据流程,数据表提供数据支持,来完成逻辑操作。
由于本系统在逻辑事务处理方面对数据库的操作比较频繁所以系统在底层连接数据库封装之后相当于一个连接数据库的工具DB UTIL,这样使用起来会更加方便而且这样进行封装还可以降低系统中代码的冗余,当我们需要连接和使用数据库时只需要调用这个工具里面的一个方法就可以了。而且通过封装可以把对数据库的操作独立起来,当需要连接不同种类的数据库时只需要加以修改就可以达到目的。
DAO层本来并无这个类,它只是Java中MVC构造里的一个model概念,主要就是里面的一些方法,而这些方法就是用来访问数据库的方法。我们在软件开发时DAO层我们一般都放接口和接口的实现类,用于来规范实现类的我们叫它接口,实现类重点用于对数据库的操纵。
MVC是一种系统研发的关键模型,M是Model模型,它是系统内部关键程序运行的核心,主要进行对数据库的各种操作。视图View是V也叫做视图,主要的作用是对一些数据进行显示。控制器Controller 是C执行从View的视图层来读取数据,然后控制用户的输入。
图4-1系统架构图
进入系统后首先要进行登录,验证你的身份,赋予你不同的权限。当你成功登录后,页面会有多个板块,分别是系统用户管理、书籍管理、书籍分类管理、书籍预订管理、取消预订管理、借书管理、还书管理、书籍捐赠管理。里面界面简单易懂,根据标示可以直接进行方便快捷的操作。
系统功能结构图如下所示。
图4-1系统功能结构图
一个好的系统它的后台数据库一定要考虑的全面,这和我们建造房子一个概念,房子不是随心所欲建起来的,一切都是在合理设计的基础是实现的,地基打牢固了房子才能建的更高。数据库如果设计的很合理,而且每个方面都能考虑到了那么这个系统才能不会出现大的问题。
本系统在数据库中存放了多张表,分别是用户表、书籍表、预订表、取消预订表、借书表、归还表、捐赠表。
系统的主要实体间关系E-R图如下图所示。
图4-7系统E-R图
此环节把概念转变成数据。由于整个数据库所处理的信息过多,就只展示几个表。book_information表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
book_information_id | int | 11 | 是 | 是 | 书籍信息ID |
book_number | varchar | 64 | 是 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
author | varchar | 64 | 否 | 否 | 作者 |
press | varchar | 64 | 否 | 否 | 出版社 |
location | varchar | 64 | 否 | 否 | 所在位置 |
book_introduction | text | 0 | 否 | 否 | 图书简介 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
hits | int | 11 | 是 | 否 | 点击数 |
praise_len | int | 11 | 是 | 否 | 点赞数 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
book_donation表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
book_donation_id | int | 11 | 是 | 是 | 书籍捐助ID |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_name | varchar | 64 | 否 | 否 | 书籍名称 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
address | varchar | 64 | 否 | 否 | 地址 |
name_of_sender | varchar | 64 | 否 | 否 | 寄件人姓名 |
telephone | varchar | 16 | 否 | 否 | 电话 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
examine_state | varchar | 16 | 是 | 否 | 审核状态 |
examine_reply | varchar | 16 | 否 | 否 | 审核回复 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
book_return_record表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
book_return_record_id | int | 11 | 是 | 是 | 还书记录ID |
loan_no | varchar | 64 | 是 | 否 | 借书编号 |
book_number | varchar | 64 | 否 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
author | varchar | 64 | 否 | 否 | 作者 |
press | varchar | 64 | 否 | 否 | 出版社 |
borrowing_time | date | 0 | 否 | 否 | 借书时间 |
actual_return_time | date | 0 | 否 | 否 | 实际还书时间 |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
borrowing_record表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
borrowing_record_id | int | 11 | 是 | 是 | 借书记录ID |
reservation_no | varchar | 64 | 否 | 否 | 预订编号 |
loan_no | varchar | 64 | 否 | 否 | 借书编号 |
book_number | varchar | 64 | 否 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
author | varchar | 64 | 否 | 否 | 作者 |
press | varchar | 64 | 否 | 否 | 出版社 |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
cancel_the_reservation表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
cancel_the_reservation_id | int | 11 | 是 | 是 | 取消预订ID |
reservation_no | varchar | 64 | 是 | 否 | 预订编号 |
book_number | varchar | 64 | 否 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
author | varchar | 64 | 否 | 否 | 作者 |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
reservation_record表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
reservation_record_id | int | 11 | 是 | 是 | 预订记录ID |
reservation_no | varchar | 64 | 否 | 否 | 预订编号 |
book_number | varchar | 64 | 否 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
press | varchar | 64 | 否 | 否 | 出版社 |
author | varchar | 64 | 否 | 否 | 作者 |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
return_request表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
return_request_id | int | 11 | 是 | 是 | 还书请求ID |
loan_no | varchar | 64 | 是 | 否 | 借书编号 |
book_number | varchar | 64 | 否 | 否 | 书籍编号 |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
title | varchar | 64 | 否 | 否 | 书名 |
author | varchar | 64 | 否 | 否 | 作者 |
press | varchar | 64 | 否 | 否 | 出版社 |
request_for_return_time | date | 0 | 否 | 否 | 请求还书时间 |
user_no | int | 11 | 否 | 否 | 用户编号 |
user_name | varchar | 64 | 否 | 否 | 用户姓名 |
book_cover | varchar | 255 | 否 | 否 | 图书封面 |
examine_state | varchar | 16 | 是 | 否 | 审核状态 |
examine_reply | varchar | 16 | 否 | 否 | 审核回复 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
book_type表:
名称 | 类型 | 长度 | 不是null | 主键 | 注释 |
book_type_id | int | 11 | 是 | 是 | 书籍类型ID |
book_type | varchar | 64 | 否 | 否 | 书籍类型 |
recommend | int | 11 | 是 | 否 | 智能推荐 |
create_time | datetime | 0 | 是 | 否 | 创建时间 |
update_time | timestamp | 0 | 是 | 否 | 更新时间 |
该系统的数据库连接方法采用的是C3P0数据连接池的方法,C3P0是开源的JDBC连接池,jdbcURL是所创建的数据库,driverClass连接数据库驱动,user为用户名,password为用户密码,acquireIncrement当连接池中的连接耗尽的时候C3P0一次同时获取的连接数,initialPoolSize初始化连接池中的连接数,minPoolSize和maxPoolSize分别是连接池中保留的最小和最大的连接数。C3P0的特点在于有自动回收空闲连接的功能。
该登录模块利用js进行设计,JavaScript函数CheckSubmit()对输入框是否为空进行验证,使用js的技术结合Mysql 2012数据库的查询语句进行登录信息的验证。首先从文本框中分别获得账号user_name和密码user_pw,将查询结果赋给rs结果集,若rs.next()返回值为空,表示数据库找不到该用户数据,若rs.next()返回值不为空,则显示登录成功,进入主界面。
用户登录流程图如下所示。
图5-1用户登录流程
用户登录流程:用户只有输入正确的用户名和密码才会成功进入系统,用户输入用户名密码后点击登录按钮,系统会进行校验该用户名是否存在,如果用户名与密码不匹配或者用户名不存在,则返回主界面。
系统登录界面如下图所示。
图5-2系统登录界面
用户登录的关键代码如下。
/**
* 登录
* @param data
* @param httpServletRequest
* @return
*/
@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<>();
if(username != null && "".equals(username) == false){
map.put("username", username);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(email != null && "".equals(email) == false){
map.put("email", email);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}
else if(phone != null && "".equals(phone) == false){
map.put("phone", phone);
resultList = service.selectBaseList(service.select(map, new HashMap<>()));
}else{
return error(30000, "账号或密码不能为空");
}
if (resultList == null || password == null) {
return error(30000, "账号或密码不能为空");
}
//判断是否有这个用户
if (resultList.size()<=0){
return error(30000,"用户不存在");
}
User byUsername = (User) resultList.get(0);
Map<String, String> groupMap = new HashMap<>();
groupMap.put("name",byUsername.getUserGroup());
List groupList = userGroupService.selectBaseList(userGroupService.select(groupMap, new HashMap<>()));
if (groupList.size()<1){
return error(30000,"用户组不存在");
}
UserGroup userGroup = (UserGroup) groupList.get(0);
//查询用户审核状态
if (!StringUtils.isEmpty(userGroup.getSourceTable())){
String res = service.selectExamineState(userGroup.getSourceTable(),byUsername.getUserId());
if (res==null){
return error(30000,"用户不存在");
}
if (!res.equals("已通过")){
return error(30000,"该用户审核未通过");
}
}
//查询用户状态
if (byUsername.getState()!=1){
return error(30000,"用户非可用状态,不能登录");
}
String md5password = service.encryption(password);
if (byUsername.getPassword().equals(md5password)) {
// 存储Token到数据库
AccessToken accessToken = new AccessToken();
accessToken.setToken(UUID.randomUUID().toString().replaceAll("-", ""));
accessToken.setUser_id(byUsername.getUserId());
tokenService.save(accessToken);
// 返回用户信息
JSONObject user = JSONObject.parseObject(JSONObject.toJSONString(byUsername));
user.put("token", accessToken.getToken());
JSONObject ret = new JSONObject();
ret.put("obj",user);
return success(ret);
} else {
return error(30000, "账号或密码不正确");
}
}
public String select(Map<String,String> query,Map<String,String> config){
StringBuffer sql = new StringBuffer("select ");
sql.append(config.get(FindConfig.FIELD) == null || "".equals(config.get(FindConfig.FIELD)) ? "*" : config.get(FindConfig.FIELD)).append(" ");
sql.append("from ").append("`").append(table).append("`").append(toWhereSql(query, "0".equals(config.get(FindConfig.LIKE))));
if (config.get(FindConfig.GROUP_BY) != null && !"".equals(config.get(FindConfig.GROUP_BY))){
sql.append("group by ").append(config.get(FindConfig.GROUP_BY)).append(" ");
}
if (config.get(FindConfig.ORDER_BY) != null && !"".equals(config.get(FindConfig.ORDER_BY))){
sql.append("order by ").append(config.get(FindConfig.ORDER_BY)).append(" ");
}
if (config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE))){
int page = config.get(FindConfig.PAGE) != null && !"".equals(config.get(FindConfig.PAGE)) ? Integer.parseInt(config.get(FindConfig.PAGE)) : 1;
int limit = config.get(FindConfig.SIZE) != null && !"".equals(config.get(FindConfig.SIZE)) ? Integer.parseInt(config.get(FindConfig.SIZE)) : 10;
sql.append(" limit ").append( (page-1)*limit ).append(" , ").append(limit);
}
log.info("[{}] - 查询操作,sql: {}",table,sql);
return sql.toString();
}
public List selectBaseList(String select) {
List<Map<String,Object>> mapList = baseMapper.selectBaseList(select);
List<E> list = new ArrayList<>();
for (Map<String,Object> map:mapList) {
list.add(JSON.parseObject(JSON.toJSONString(map),eClass));
}
return list;
}
在浏览器的地址栏里输入对应的地址,就可以跳转到德庆县乡村教育图书管理系统的首页,这里也是浏览者访问系统的入口。
首页载入流程图如下所示。
图5-3首页载入流程
首页载入流程:系统先连接数据库,显示界面参数初始化,读取数据库的数据表,显示前端样式,对数据按添加时间排序,按照模板设计位置显示数据,刷新显示界面,断开数据库连接。
首页如下图所示。
图5-4首页界面
系统的用户通过自行注册生成,在系统首页点击用户注册菜单,系统跳转到对应的注册页面。点击重置按钮,清空所填数据,点击注册按钮完成注册。
用户注册流程图如下所示。
图5-5用户注册流程
注册个人信息实现流程为:填写个人信息,系统使用JQuery选择器获取在网页中输入的注册信息,再对联系方式、登录密码等信息进行验证,验证通过后用Ajax异步请求方式向服务器发送请求并把数据传送到后台,然后验证用户名是否已存在,如果已存在则注册失败提示“用户名已存在”;如果用户表中没有该用户名则把用户信息加入数据库,把操作状态以json字符串方式返回到前台。Ajax请求成功接收到返回的数据时会触发成功回调函数,然后解析返回的json字符串,系统根据返回信息弹出提示框,注册成功后返回登录页。
用户注册界面如下图所示。
图5-6用户注册界面
用户注册关键代码如下所示。
/**
* 注册
* @return
*/
@PostMapping("register")
public Map<String, Object> signUp(HttpServletRequest request) throws IOException {
// 查询用户
Map<String, String> query = new HashMap<>();
Map<String,Object> map = service.readBody(request.getReader());
query.put("username",String.valueOf(map.get("username")));
List list = service.selectBaseList(service.select(query, new HashMap<>()));
if (list.size()>0){
return error(30000, "用户已存在");
}
map.put("password",service.encryption(String.valueOf(map.get("password"))));
service.insert(map);
return success(1);
}
public Map<String,Object> readBody(BufferedReader reader){
BufferedReader br = null;
StringBuilder sb = new StringBuilder("");
try{
br = reader;
String str;
while ((str = br.readLine()) != null){
sb.append(str);
}
br.close();
String json = sb.toString();
return JSONObject.parseObject(json, Map.class);
}catch (IOException e){
e.printStackTrace();
}finally{
if (null != br){
try{
br.close();
}catch (IOException e){
e.printStackTrace();
}
}
}
return null;
}
public void insert(Map<String,Object> body){
E entity = JSON.parseObject(JSON.toJSONString(body),eClass);
baseMapper.insert(entity);
log.info("[{}] - 插入操作:{}",entity);
}
管理员进行书籍添加等,在书籍模块实现书籍的信息添加,管理员管理系统的所有书籍信息,在列表p实现书籍的管理。
书籍添加流程图如下所示。
图5-7信息书籍流程
管理员登录成功后,浏览书籍信息页面,输入书籍名称,添加该书籍信息,修改书籍信息,返回书籍相关界面。
书籍添加界面如下图所示。
图5-8书籍添加界面
用户可以在线进行借书申请提交,通过id传参,找到该书籍,在借书添加页提交借书申请单。
借书流程如下图所示。
图5-9借书流程
借书记录界面如下图所示。
图5-10借书记录界面
借书记录界面逻辑代码如下:
public Map<String, Object> success(Object o) {
Map<String, Object> map = new HashMap<>();
if (o == null) {
map.put("result", null);
return map;
}
if (o instanceof List) {
if (((List) o).size() == 1) {
o = ((List) o).get(0);
map.put("result", o);
}else {
String jsonString = JSONObject.toJSONString(o);
JSONArray objects = service.covertArray(JSONObject.parseArray(jsonString));
map.put("result", objects);
}
} else if (o instanceof Integer || o instanceof String) {
map.put("result", o);
} else {
String jsonString = JSONObject.toJSONString(o);
JSONObject jsonObject = JSONObject.parseObject(jsonString);
JSONObject j = service.covertObject(jsonObject);
map.put("result", j);
}
return map;
}
用户在线进行书籍归还提交,通过id传参,找到该书籍,在还书请求添加页提交还书表单。
还书流程如下图所示。
图5-11还书流程
还书请求界面如下图所示。
图5-12还书请求界面
还书请求界面逻辑代码如下:
public Map<String, Object> error(Integer code, String message) {
Map<String, Object> map = new HashMap<>();
map.put("error", new HashMap<String, Object>(4) {{
put("code", code);
put("message", message);
}});
return map;
}
经过用户登录后,页面跳转至管理员功能模块页。
主界面如下图所示。
图5-13主界面
管理员对系统用户的管理,在列表实现管理员用户的管理,包括录入、删除、修改,修改密码通过SESSION获取用户名,然后输入新密码,提交,使用sql命令更新密码。
用户管理界面如下图所示。
图5-14用户管理界面
用户管理界面逻辑代码如下:
@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-15预订记录管理界面
预订记录管理界面关键代码如下:
@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);
}
}
管理员在tushuxinxi_add.jsp发布书籍,跳转至书籍添加表单,提交书籍信息,包括书籍编号、名称、类别、作者图书封面等,信息提交后,数据库的书籍信息表刷新数据,系统将书籍信息展示出来。
书籍信息管理的流程如所示。
图5-16书籍信息管理流程
书籍信息管理的界面如所示。
图5-17书籍信息管理界面
书籍类型管理的界面如所示。
图5-18书籍类型管理界面
书籍信息管理界面关键代码如下:
@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);
}
新增一条数据,通过post传入一个json对象,然后经过request.getReader(),最后经过readBody()转成一个Map,含有String和Object,key用的是字段名,Object存放数据,最终得到Map,insert用拼装sql,读取body,组装成一个insert对象,runCountSql()语句
在这个产品被投入使用前,首先需要进行试用,这是重要的环节。考虑到某个部分的开发没有缺陷情况下,把各种模块拼接,也有一定概率就存在矛盾。这就好比每个人都很独特,但聚在一起就显得杂乱无章,需要保证有默契的配合。对于测试,要看它的各项内容是否契合的原则。若与最初定下的标准有一定程度上的出入,那么就需要做出一些调整,让最终的大方向朝着目标前进。
登录测试用例如下表所示。
表6-1登录测试用例
输入 | 输出 | |
用户名 | 密码 | |
空 | 空 | 用户名和密码不能为空 |
Kkk | aaa | 用户名长度不允许,请重新输入! |
2109402315 | 123456 | 用户名出错,请重新输入! |
sssss | 123456 | 用户名出错,请重新输入! |
注册测试用例如下表所示。
表6-2注册测试用例
输入 | 输出 | |||
用户名 | 密码 | 确认密码 | 邮箱 | |
空 | 空 | 空 | 空 | 用户名和密码不能为空 |
Kkk | aaa | aaa | 23@qq.com | 注册成功 |
210 | aaa | abc | 23@qq.com | 注册失败,两次密码不一致 |
书籍测试用例如下表所示。
表6-3添加书籍测试用例
输入 | 输出 | |||
名称 | 类别 | 作者 | 备注 | |
空 | 空 | 空 | 空 | 添加失败 |
书籍1 | A | 罗贯中 | 你好 | 添加成功 |
空 | A | 罗贯中 | 你好 | 添加失败,名称不能为空 |
书籍2 | 空 | 罗贯中 | 你好 | 添加失败,请选择类别 |
图书预订测试用例如下表所示。
表6-4图书预订测试用例
输入 | 输出 | |||
名称 | 类别 | 预订人 | 备注 | |
空 | 空 | 空 | 空 | 添加失败 |
图书1 | A | 111 | 你好 | 添加成功 |
空 | A | 111 | 你好 | 添加失败,名称不能为空 |
图书2 | 空 | 111 | 你好 | 添加失败,请选择类别 |
经过测试,得到测试结果如下表所示。
表6-5测试结果
序号 | 测试项目 | 内容和目的 | 测试结果 |
| 用户登录 | 输入正确用户名与密码 | 可以登录 |
输入错误用户名与密码 | 提示错误的信息 | ||
| 书籍管理 (添加,修改,删除) | 输入正确信息 | 成功完成 |
输入错误信息 | 操作失败 | ||
| 修改登录密码 | 修改新的密码 | 成功完成 |
| 书籍预订管理 (添加,修改,删除) | 输入正确信息 | 成功完成 |
输入错误信息 | 操作失败 | ||
| 借书记录管理 (添加,修改,删除) | 输入正确信息 | 成功完成 |
输入错误信息 | 操作失败 | ||
| 书籍类型管理 (添加,修改,删除) | 输入正确信息 | 成功完成 |
输入错误信息 | 操作失败 | ||
| 还书记录管理 (添加,修改,删除) | 输入正确信息 | 成功完成 |
输入错误信息 | 操作失败 |
本次毕业论文的主要是利用SSM+MySQL开发一个安全可靠,操作简易,同时具备业务可扩展的德庆县乡村教育图书管理系统。本文详细的论述了德庆县乡村教育图书管理系统的设计和开发,本系统的所有事务逻辑都是按照系统的需求分析进行设计的,系统有普通用户和系统管理员两种角色,本系统多处采用了Ajax的异步交互技术,同时它也叫异步交互技术,利用它我们可以让网页的局部进行数据刷新操作,Ajax和传统的数据更新技术大大增加了客户的体验程度,由于是对局部进行操作那么就减少了一些繁琐而又不必要的操作,减轻了服务器对页面解析的负担。
与其他系统相比,本系统有自身的优点,
例如:
(1)创新性强;
(2)业务逻辑性强,安全性高,在一些重要的功能模块需要通过审查之后才可使用;
(3)移植性高,在所有window平台都可使用。
当然也还有很多需要进一步改进的地方:
(1)系统大多数页面都是全局刷新,缺乏局部刷新,这将增加服务器的压力,如果有大量用户在同一时间段操作同一个功能模块,可能会导致查询缓慢;
(2)页面没有经过专业的UI设计,美观程度不及其他市场其他网站系统,有待改善。
参考文献
[1]段学敏,高卫辉.图书管理与信息化结合途径初探[J].参花(下),2022(02):122-124.
[2]王小刚.互联网时代下的学校图书管理信息化建设[J].数字通信世界,2022(02):122-124.
[3]李鹏.新公共管理理念在图书管理中的创新应用[J].产业与科技论坛,2022,21(03):285-286.
[4]林辉.基于Java Web的渭南市大荔县图书管理系统的设计与实现[J].电子设计工程,2021,29(24):155-158+163.
[5]李东阳.利用信息技术优势,做好图书管理工作[J].新课程,2021(50):216.
[6]冯晓娟.信息技术在图书管理中的运用研究[J].文化产业,2021(33):40-42.
[7]王丹.大数据时代公共图书管理的创新路径[J].传媒论坛,2021,4(22):146-148.
[8]罗莉霞,高何裕.基于B/S的高校图书管理与个性化推荐系统的设计与实现[J].技术与市场,2021,28(11):184-185.
[9]杜秋英.基于网络环境下公共图书馆图书管理的措施[J].科技资讯,2021,19(30):146-148.
[10]黄波.基于SSM乡村教育图书管理系统设计与实现[J].信息与电脑(理论版),2021,33(19):124-126.
[11]何冰,刘瑞华.探索新媒体时代公共图书管理的有效途径[J].办公室业务,2021(19):172-173.
[12]岳晓玲.浅论信息化建设视角下的图书管理[J].文化产业,2021(25):85-87.
[13]曾莹珊.中职学校图书管理信息化建设的必要性与实现路径[J].新课程教学(电子版),2021(16):155-156.
[14]李燕.图书管理工作中存在的问题和解决措施[J].办公室业务,2021(15):161-162.
[15]张雪红.互联网时代图书管理信息化建设策略研究[J].中国高新科技,2021(14):39-40.
[16] Li Dongyang Make use of the advantages of information technology to do a good job in library management [J] New curriculum, 2021 (50): 216
[17] Feng Xiaojuan Research on the application of information technology in library management [J] Cultural industry, 2021 (33): 40-42
致谢
经过几个月时间的努力终于完成了这篇文章,在文章的写作与研究的过程中遇到了很多困难,都在同学和老师的帮助下解决了。尤其非常感谢我最敬爱的老师,他对我进行了无私的指导和帮助,不厌其烦的帮助进行文章的修改。老师严谨的治学态度、渊博的学术知识、诲人不倦的敬业精神以及宽容的待人风范使我获益颇丰。此外,在校图书馆查找资料的时候,图书馆的老师也给我提供了很多方面的支持与帮助。在此,向帮助和指导过我的老师表示最衷心的感谢!感谢这篇文章所涉及到的各位学者。本文引用了数位学者的文献,如果没有各位学者的研究成果的帮助和启发,我将很难完成本篇文章的写作。感谢我的同学、朋友以及所在单位的同事,在我写文章的过程中给与了我很多素材和帮助,还在文章的撰写和排版过程中提供热情的帮助。同时,感谢我的室友对我的热心指导和帮助,经常有不懂之处都是大家在帮助我,才使得我比较顺利的完成了这篇文章。由于我水平有限,所写文章难免有不足之处,恳请各位老师和学友批评和指正!
请关注点赞+私信博主,免费领取项目源码