目 录
大数据时代下,数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求,利用互联网服务于其他行业,促进生产,已经是成为一种势不可挡的趋势。在图书馆管理的要求下,开发一款整体式结构的图书管理系统,将复杂的系统进行拆分,能够实现对需求的变化快速响应、系统稳定性的保障,能保证平台可持续、规模化发展的要求。
此图书管理系统的开发项目采用Java开发语言,数据使用的是MYSQL,系统就论题的各类需求分析说明做出解释,然后再就系统的总体设计和详细设计做出论述,给出了系统总体结构的搭建方法。从而满足大部分中小型电子商务网站的需求。
关键词:图书管理系统;Java;SpringBoot框架;MYSQL数据库
Abstract
In the era of big data, data is growing explosively. In order to meet the trend of the information age and the requirements of information security, using the Internet to serve other industries and promote production has become an unstoppable trend. Under the requirements of library management, develop a holistic library management system that breaks down complex systems to achieve rapid response to changes in demand, ensure system stability, and meet the requirements of sustainable and large-scale development of the platform.
The development project of this book management system adopts Java development language, and the data is using MYSQL. The system provides explanations for various requirements analysis explanations of the topic, and then discusses the overall and detailed design of the system, providing a method for building the overall structure of the system. To meet the needs of most small and medium-sized e-commerce websites.
Keywords: Library management system; Java; SpringBoot framework; MYSQL database
1 绪论
1.1 研究背景及意义
图书管理系统是对传统图书馆管理模式的一种改进,它可以充分利用网络的特性,随时随地的对图书进行管理,不受时空的局限,很大程度地简化了图书管理的过程,减轻了管理员工作,为借阅者提供便捷的途径,提高了图书的利用率[1] [2]。本系统的优势主要体现在如下几个方面:
(1)管理员通过数据库管理和维护系统可以对借阅者和图书进行管理和维护。管理员可以对后台数据中的信息进行删除、修改、更新等基本操作以管理和维护借阅者信息。
(2)用户可以通过图书作者、图书名、ISBN、出版社、主题词、图书书号进行查询,以便用户对图书信息的快速检索。
(3)图书的添加,新书的出版可以及时的输入数据库以待取用,已经报废的旧书及时的删除或禁用。
(4)借阅者可以在线随时查询图书信息,借阅图书,等待管理员审核通过。
1.2国内外研究现状
当前图书管理系统中,主流的国内产品主要有汇文软件产品、ADLIB2.0、金盘软件产品等,主流的国外产品主要以ExLibris的Aleph500为代表。近年来,随着Web2.0的发展和Library2.0研究的深入,给图书管理系统带来了新的理念和思路,图书管理系统很好的融合了Library2.0的理念和Web2.0的技术。当前图书管理系统普遍存在的问题有:①图书馆资源与服务的相对隔离与孤立;②不能全面集成图书馆的业务和管理工作;③信息孤岛现象日益严重;④难以体现图书馆的管理思路。图书管理系统的发展趋势:①融合图书馆的管理理念;②数据驱动管理;③开放合作的理念;④云计算;⑤整合服务评价体系。
2 图书管理系统系统分析
本章内容概括了图书管理系统的可行性分析、功能分析以及用例分析。
2.1 系统可行性分析
技术可行性分析
图书管理系统存储所使用的是mysql数据库以及开发中所使用的是IDEA、Tomcat这些开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用SpringBoot框架进行开发,使系统的可扩展性和维护性更佳。
经济可行性分析
在开发图书管理系统中所使用的开发软件像IDEA开发工具、Tomcat8.0服务器、MySQL5.7数据库、Photoshop图片处理软件等,这些都是开源免费的,而且系统的开发工具从网上都可以直接下载,因此在经济方面是可行的。
操作可行性分析
此次项目设计的时候我参考了很多类似系统的成功案例,对它们的操作界面以及功能都进行了系统的分析,将众多案例结合在一起,突出以人为本简化操作,所以具有基本计算机知识的人都会操作本项目。因此操作可行性也没有问题。
2.2 系统功能分析
图书管理系统我划分为了用户管理模块和管理员模块这两大部分。
(1)注册登录:当用户想要对系统中所实现的功能进行查询管理的时候,就必须进行登录到系统当中,如果没有账号的话,在登录界面,点击“注册”按钮就会跳转到注册的界面,根据提示填写好注册信息,添加提交,学生的信息在数据库中就添加完成了,然后再输入填写好的账号和密码进行登录;
(2)图书信息:点击“图书信息”这个菜单,可以查看到系统中所有添加的图书信息,支持通过图书名称、类别、作者等关键词进行查询,如果想要了解某一图书的详细信息,点击后面的“详情”会进入详情查看界面;
(3)图书借阅:进入个人中心点击“图书借阅”这个按钮对选中的图书后选择借阅时间、填写借阅天数、次数、说明等信息申请借阅;
(4)图书归还:进入个人中心点击“图书借阅”这个按钮已借阅的图书进行详情查看和归还操作;
管理员端:
(1)系统用户管理:管理员可以对系统中所有的用户角色进行管控,包含了管理员、以及用户两种角色,如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以查看到了,可以点击用户后面的“删除”按钮直接删除某一用户。
(2)图书信息管理:点击“图书信息管理”这一按钮可以查看到系统当中所有的图书信息,支持通过图书名称进行查询图书信息,如果想要添加新的图书,点击“添加”按钮,然后根据提示填写好图书的具体信息,点击提交所添加的图书信息在数据库就保存下来了,也可以选择要删除的图书直接点击“删除按钮”进行图书删除。
(3)图书借阅管理:进入首页工具栏点击“借阅管理”这个按钮可以查看所有借阅信息,可以进行删改查操作之外,还以进行归还操作。
(4)图书归还管理:进入首页工具栏点击“归还管理”这个按钮可以查看所有归还信息,可以进行删改查等操作。
(6)网站公告管理:点击“网站公告管理”这个菜单,可以查看到系统中所有添加的网站公告信息,支持通过标题对网站公告信息进行查询,添加、删除等操作。
2.2.2 非功能性分析
图书管理系统的非功能性需求比如图书管理系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:
表3-1图书管理系统非功能需求表
安全性 | 主要指图书管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指图书管理系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响图书管理系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着图书管理系统的页面展示内容进行操作,就可以了。 |
可维护性 | 图书管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
2.3 系统用例分析
图书管理系统的完整UML用例图分别是图2-1和图2-2。

图2-1 图书管理系统用户角色用例图

3.4本章小结
本章主要通过对图书管理系统的可行性分析、功能需求分析、系统用例分析,确定整个图书管理系统要实现的功能。同时也为图书管理系统的代码实现和测试提供了标准。
本章主要讨论的内容包括图书管理系统的功能模块设计、数据库系统设计。
3.1系统模块设计
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本图书管理系统中的用例。那么接下来就要开始对本图书管理系统的架构、主要功能和数据库开始进行设计。图书管理系统根据前面章节的需求分析得出,其总体设计模块图如图3-2所示。

图3-1 图书管理系统功能模块图
3.2 数据库设计
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.2.1 数据库概念结构设计
下面是整个图书管理系统中主要的数据库表总E-R实体关系图。

图3-2 图书管理系统总E-R关系图
通过上一小节中图书管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_borrowing_id | int | 10 | 0 | N | Y | 图书借阅ID | |
2 | borrowing_form_number | varchar | 64 | 0 | Y | N | 借阅单号 | |
3 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
4 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
5 | author | varchar | 64 | 0 | Y | N | 作者 | |
6 | user | int | 10 | 0 | Y | N | 0 | 用户 |
7 | name | varchar | 64 | 0 | Y | N | 姓名 | |
8 | contact_number | varchar | 64 | 0 | Y | N | 联系电话 | |
9 | borrowed_quantity | varchar | 64 | 0 | Y | N | 借阅数量 | |
10 | borrowing_notes | text | 65535 | 0 | Y | N | 借阅备注 | |
11 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
12 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
13 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_classification_id | int | 10 | 0 | N | Y | 图书分类ID | |
2 | book_categories | varchar | 64 | 0 | Y | N | 图书类别 | |
3 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
4 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
5 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_information_id | int | 10 | 0 | N | Y | 图书信息ID | |
2 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
3 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
4 | book_categories | varchar | 64 | 0 | Y | N | 图书类别 | |
5 | cover | varchar | 255 | 0 | Y | N | 封面 | |
6 | author | varchar | 64 | 0 | Y | N | 作者 | |
7 | press | varchar | 64 | 0 | Y | N | 出版社 | |
8 | inventory | int | 10 | 0 | Y | N | 0 | 库存 |
9 | book_introduction | longtext | 2147483647 | 0 | Y | N | 图书介绍 | |
10 | hits | int | 10 | 0 | N | N | 0 | 点击数 |
11 | praise_len | int | 10 | 0 | N | N | 0 | 点赞数 |
12 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
13 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
14 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_return_id | int | 10 | 0 | N | Y | 图书归还ID | |
2 | borrowing_form_number | varchar | 64 | 0 | N | N | 借阅单号 | |
3 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
4 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
5 | author | varchar | 64 | 0 | Y | N | 作者 | |
6 | user | int | 10 | 0 | Y | N | 0 | 用户 |
7 | name | varchar | 64 | 0 | Y | N | 姓名 | |
8 | borrowed_quantity | varchar | 64 | 0 | Y | N | 借阅数量 | |
9 | return_remarks | text | 65535 | 0 | Y | N | 归还备注 | |
10 | recommend | int | 10 | 0 | N | N | 0 | 智能推荐 |
11 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
12 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
整个图书管理系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。
4 图书管理系统详细设计与实现
图书管理系统的详细设计与实现主要是根据前面的图书管理系统的需求分析和图书管理系统的总体设计来设计页面并实现业务逻辑。主要从图书管理系统界面实现、业务逻辑实现这两部分进行介绍。
4.1用户功能模块
4.1.1 前台首页界面
在图书管理系统的前台首页界面上采用了上+中+下的方式来布局界面,最右上角是登录+注册这+搜索这三个链接,下面依次是导航栏+轮播图以及下面的公告栏,下面依次是推荐的图书商城展示,其主界面展示如下图4-1所示。

图4-1 前台首页界面图
4.1.2 用户注册界面
不是图书管理系统中正式用户的是可以在线进行注册的,当填写上自己的账号+设置密码+确认密码+昵称+邮箱+手机号+身份后+用户名再点击“注册”按钮后将会先验证输入的有没有空数据,再次验证密码和确认密码是否是一样的,最后验证输入的账户名和数据库表中已经注册的账户名是否重复,只有都验证没问题后即可注册成功。其用注册界面展示如下图4-2所示。

图4-2 前台用户注册界面图
4.1.3 用户登录界面
图书管理系统中的前台上注册后的用户是可以通过自己的账户名和密码进行登录的,当用户输入完整的自己的账户名和密码信息并点击“登录”按钮后,将会首先验证输入的有没有空数据,再次验证输入的账户名+密码和数据库中当前保存的用户信息是否一致,只有在一致后将会登录成功并自动跳转到图书管理系统的首页中;否则将会提示相应错误信息,用户登录界面如下图4-3所示。

图4-3用户登录界面图
4.1.4 图书信息列表界面
用户可以在图书信息列表界面看到所有图书信息进行查询管理。图书信息列表界面如下图4-4所示。

图4-4 图书信息列表界面图
4.2管理员功能模块
4.2.1 登录界面
图书管理系统中的管理人员是可以对前台登录的用户进行管理。登录界面如下图4-5所示。

图4-5登录界面图
图书管理系统中的管理人员是可以对网站发布的公告进行管控,网站公告界面如下图4-6所示。

图4-6网站公告界面图
4.2.3 图书借阅界面
图书管理系统中的管理人员是可以对图书管理系统内的不同图书的分类下的图书信息进行维护和管理的,支持查看到各个图书的借阅量情况以及添加+删除图书。图书借阅界面如下图4-7所示。

图4-7图书借阅界面图
4.2.4图书归还界面
图书管理系统中的管理人员是可以对图书管理系统内的图书归还进行在线管理等,同时支持根据借阅单号来具体检索图书归还记录信息。图书归还界面如下图4-8所示。

图4-8图书归还界面图
5系统测试
5.1 系统测试用例
系统测试包括:用户登录功能测试、用户注册功能测试、图书展示功能测试、图书添加功能测试,如表5-1、5-2、5-3、5-4所示:
表5-1 用户登录功能测试表
测试名称 | 测试功能 | 操作 | 操作过程 | 预期结果 | 测试结果 |
用户登录模块测试 | 正确输入用户信息,用户成功登录 | 输入用户的信息 | 1.在密码框输入用户密码。2.点击登录 | 跳转到首页 | 正确 |
用户注册功能测试:
表5-2 用户登录功能测试表
测试名称 | 测试功能 | 操作 | 操作过程 | 预期结果 | 测试结果 |
用户注册模块测试 | 正确输入用户星系,完成用户注册 | 输入用户的基本信息 | 在注册页面填写用户相应的信息,然后点击“注册”按钮。 | 提示成功并跳转到登录界面 | 正确 |
用户注册模块测试 | 用户注册失败 | 用户两次输入密码不一致 | 用户在注册页面填写信息时输入两个不一致的密码然后点击“注册”按钮。 | 注册失败提示两次密码输入不一致 | 正确 |
图书信息界面测试:
表5-3 图书信息界面测试表
测试名称 | 测试功能 | 操作 | 操作过程 | 预期结果 | 测试结果 |
图书信息功能模块测试 | 图书信息正常的显示 | 浏览图书信息 | 在前台首页选择一个图书分类进入分类列表,然后选择一个图书 | 进入该图书的详细信息界面 | 正确 |
通过编写图书管理系统的测试用例,已经检测完毕用户登录模块、用户注册模块、图书分类展示模块、图书添加模块功能测试,通过这4大模块为图书管理系统的后期推广运营提供了强力的技术支撑。
至此,图书管理系统已经结束,在开发前做了许多的准备,在本系统的设计和开发过程中阅览和学习了许多文献资料,从中我也收获了很多宝贵的方法和设计思路,对系统的开发也起到了很重要的作用,系统的开发技术选用的都是自己比较熟悉的,比如Web、Java技术、MYSQL,这些技术都是在以前的学习中学到了,其中许多的设计思路和方法都是在以前不断地学习中摸索出来的经验,其实对于我们来说工作量还是比较大的,但是正是由于之前的积累与准备,才能顺利的完成这个项目,由此看来,积累经验跟做好准备是十分重要的事情。
当然在该系统的设计与实现的过程中也离不开老师以及同学们的帮助,正是因为他们的指导与帮助,我才能够成功的在预期内完成了这个系统。同时在这个过程当中我也收获了很多东西,此系统也有需要改进的地方,但是由于专业知识的浅薄,并不能做到十分完美,希望以后有机会可以让其真正的投入到使用之中。
[1]易忠芹.智慧图书馆中智能化技术的应用[J].智能建筑与智慧城市,2023(09):133-135.DOI:10.13655/j.cnki.ibci.2023.09.040.
[2]王丽平.新形势下高校图书馆图书管理工作的优化策略研究[J].参花(下),2023(09):116-118.
[3]王丽平.大数据背景下高校图书馆图书管理信息化研究[J].参花(上),2023(08):98-100.
[4]庞嵩昊,李盈,赵艺等.基于Vue和SpringBoot前后端分离的宠物服务系统的设计与实现[J].电脑知识与技术,2023,19(21):42-45.DOI:10.14004/j.cnki.ckt.2023.1068.
[5]银莉,杜啸楠.基于SpringBoot和Vue的校园积分系统的设计与实现[J].集成电路应用,2023,40(07):414-415.DOI:10.19339/j.issn.1674-2583.2023.07.187.
[6]李琴,崔名扬,钱奕文等.基于SpringBoot的研究生学术档案管理系统开发[J].电脑知识与技术,2023,19(18):46-48+51.DOI:10.14004/j.cnki.ckt.2023.0900.
[7]李大志.Java Web在高校图书管理系统中的应用研究[J].中国信息化,2023(06):64-65.
[8]时业茂,颜晓宏,刘卫.基于Spring Boot整合SSMP框架实现图书管理系统[J].电脑编程技巧与维护,2023(06):82-84.DOI:10.16184/j.cnki.comprg.2023.06.044.
[9]文裕.高校图书管理与信息化结合途径初探[J].中国民族博览,2023(10):254-256.
[10]周伟.基于图书管理系统的大数据应用研究[J].网络安全技术与应用,2023(05):71-73.
[11]Kulkarni M A ,Pandiyan M ,Patankar P G . Smart Usage of Koha: An Open-Source Library Management System[J]. American Journal of Information Science and Technology,2023,7(1).
[12]Kandhro A I ,Ali F ,Wagan A A , et al. Safe and secure: an automated library management system for monitoring book rotation using face recognition[J]. International Journal of Electronic Security and Digital Forensics,2023,15(3).
图书管理系统的完成,标志着我即将结束在XXX大学的校园生活并跨入社会。在即将毕业的此刻,我想对所有帮助过我的师长、同学和亲人表达我发自内心的谢意。
感谢各位老师,学院使我从懵懂一步步走向成熟。在这里每个老师都拥有着最大的善意和耐心,来教育我们这群大孩子。学院举办的各类活动是给予我锻炼自己的机会,正是这些机会让我成为了更好的自己,提升了自己各方面的能力。
最后,我要对即将参与本篇论文审阅和答辩的各位老师表示感谢。