基于web的基于web的图书管理系统的设计与实现 计算机专业毕业设计源码74010

                                                              目  录

摘要

Abstract

1.绪论

1.1 研究背景及意义

1.2国内外研究现状

1.3论文结构安排

2 基于web的图书管理系统系统分析

2.1 系统可行性分析

技术可行性分析

经济可行性分析

操作可行性分析

2.2 系统功能分析

2.2.1 功能性分析

2.2.2 非功能性分析

2.3 系统用例分析

3.4本章小结

3 基于web的图书管理系统总体设计

3.1系统模块设计

3.2 数据库设计

3.2.1 数据库概念结构设计

3.3.2 数据库逻辑结构设计

3.4本章小结

4 基于web的图书管理系统详细设计与实现

4.1用户功能模块

4.1.1 前台首页界面

4.1.2 用户注册界面

4.1.3 用户登录界面

4.1.4 图书目录列表界面

4.2管理员功能模块

4.2.1 轮播图管理界面

4.2.2系统用户界面

4.2.3借阅信息界面

4.2.4归还信息界面

4.2.5行为分析界面

5系统测试

5.1 系统测试用例

5.2 系统测试结果

结论

参考文献

致  谢

摘要

在当今数字化与信息化高速发展的时代背景下,基于web的图书管理系统的现代化转型显得尤为重要。传统的图书管理方式往往受限于人工操作、效率低下以及信息检索困难等问题,无法满足现代图书馆对高效、便捷、智能化的管理需求。因此,开发一套基于Web的基于web的图书管理系统,不仅能够有效提升图书管理的效率,还能为读者提供更加便捷、个性化的服务体验。

本设计旨在构建一个功能全面、易于操作、用户友好的Web基于web的图书管理系统。该系统将采用先进的Web开发技术,结合数据库管理系统,实现图书目录的录入、查询、借阅、归还等核心功能,并通过用户权限管理确保系统数据的安全性和稳定性。同时,系统还将支持在线借阅、图书推荐等增值服务,以满足不同用户群体的多样化需求。

本系统采用Java开发语言,数据库是Mysql,使用springboot技术开发。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。

关键词:图书管理系统;Java语言;SpringBoot框架;MYSQL数据库

                                                       Abstract

In the current era of rapid development of digitalization and informatization, the modernization transformation of web-based library management systems is particularly important. Traditional book management methods are often limited by manual operations, low efficiency, and difficulties in information retrieval, which cannot meet the modern library's requirements for efficient, convenient, and intelligent management. Therefore, developing a web-based book management system can not only effectively improve the efficiency of book management, but also provide readers with a more convenient and personalized service experience.

This design aims to build a web based book management system that is comprehensive, easy to operate, and user-friendly. The system will adopt advanced web development technology, combined with a database management system, to achieve core functions such as book information input, query, borrowing, and return, and ensure the security and stability of system data through user permission management. At the same time, the system will also support value-added services such as online borrowing and book recommendations to meet the diverse needs of different user groups.

This system is developed using Java programming language, MySQL database, and Springboot technology. During the design process, the system code was fully ensured to have good readability, practicality, scalability, universality, ease of maintenance, ease of operation, and concise pages.

Keywords: Library management system; Java language; SpringBoot framework; MYSQL database;

.绪论

1.1 研究背景及意义

随着信息技术的迅猛发展,图书馆作为知识信息的重要集散地,其管理方式和服务模式正面临着前所未有的挑战和机遇。传统的图书管理方式不仅效率低下,难以满足读者日益增长的信息需求,而且在信息检索、资源共享等方面也显得力不从心。因此,研究并开发一套基于Web的图书管理系统具有重要的现实意义和深远的发展前景。

首先,基于Web的图书管理系统能够显著提升图书管理的效率。通过自动化的信息录入、查询和更新功能,该系统能够大大减少人工操作,降低管理成本,提高图书资源的利用率。同时,系统支持多用户并发访问,使得读者可以随时随地通过网络进行图书的借阅、归还和查询等操作,极大地提升了服务效率和用户体验。

其次,该系统能够优化图书资源配置,提高资源共享效率。通过系统平台,图书馆可以实现图书资源的数字化、网络化和智能化管理,使得图书资源得到更加充分的利用。同时,系统还支持多馆合作、资源共享,使得不同图书馆之间的图书资源能够得到有效整合和优化配置,为读者提供更加丰富的阅读选择。

最后,基于Web的图书管理系统还具有广阔的应用前景和发展空间。随着大数据等技术的不断发展,该系统可以进一步实现智能化推荐、个性化服务等高级功能,为读者提供更加精准、便捷和高效的服务。同时,该系统还可以与移动应用、社交媒体等进行融合,实现更加多元化的服务模式和渠道,满足读者在不同场景下的阅读需求。

综上所述,基于Web的图书管理系统的研究背景是信息技术发展的必然结果,其意义在于提升图书管理效率、优化资源配置、拓展服务模式和满足读者需求。因此,该系统对于推动图书馆事业的持续发展和创新具有重要意义。

1.2国内外研究现状

在国内,随着信息技术的不断进步和普及,越来越多的图书馆开始重视并引入基于Web的图书管理系统。这些系统不仅实现了图书目录的在线录入、查询、借阅和归还等基本功能,还通过集成先进的技术手段,如云计算、大数据和人工智能等,进一步优化了图书馆的管理和服务流程。同时,国内的研究者还在系统技术应用和创新上进行了有益的探索,以提高系统的综合能力和用户体验。

而在国外,基于Web的图书管理系统的研究也取得了显著的进展。许多大型图书馆和学术机构已经成功开发了功能强大、用户友好的图书管理系统,并在实际运营中取得了良好的效果。这些系统不仅支持多语言、多平台的使用,还提供了丰富的增值服务,如在线预约、图书推荐等,以满足不同用户群体的需求。此外,国外的研究者还注重系统的人机交互设计和可用性提升,使得图书管理系统更加便捷和直观,提高了用户对系统的接受度和满意度。

总体来说,基于Web的图书管理系统在国内外均得到了广泛的关注和应用,并呈现出不断发展和完善的趋势。随着技术的不断进步和市场的不断变化,我们有理由相信,未来的图书管理系统将更加智能化、高效化和个性化,为图书馆事业的发展注入新的活力。

1.3论文结构安排

论文将分层次经行编排,除去论文摘要、目录、致谢、文献参考部分,正文部分还会对网站需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:

第1章 交代了项目的背景以及开发的实际意义。

第2章 对本系统的可行性、功能需求展开分析。

第3章 阐述了项目的总体设计。

第4章 阐明了基于web的图书管理系统详细功能的实现,主要根据技术性的功能模块功能实现。

第5章 罗列了部分系统调试与测试的记录。

第6章 介绍了基于web的图书管理系统的结论。

2 基于web的图书管理系统系统分析

本章内容概括了基于web的图书管理系统的可行性分析、功能分析以及用例分析。

2.1 系统可行性分析

技术可行性分析

基于web的图书管理系统存储所使用的是mysql数据库以及开发中所使用的是IDEA、Tomcat这些开发工具的使用,能够给我们的编写工作带来许多的便利。系统使用SpringBoot框架进行开发,使系统的可扩展性和维护性更佳。

经济可行性分析

在开发基于web的图书管理系统中所使用的开发软件像IDEA开发工具、Tomcat8.0服务器、MySQL5.7数据库、Photoshop图片处理软件等,这些都是开源免费的,而且系统的开发工具从网上都可以直接下载,因此在经济方面是可行的。

操作可行性分析

此次项目设计的时候我参考了很多类似系统的成功案例,对它们的操作界面以及功能都进行了系统的分析,将众多案例结合在一起,突出以人为本简化操作,所以具有基本计算机知识的人都会操作本项目。因此操作可行性也没有问题。

2.2 系统功能分析

2.2.1 功能性分析

基于web的图书管理系统我划分为了用户管理模块和管理员模块这两大部分。

用户端:

  1. 注册登录:当用户想要对系统中所实现的功能进行查询管理的时候,就必须进行登录到系统当中,如果没有账号的话,在登录界面,点击“注册”按钮就会跳转到注册的界面,根据提示填写好注册信息,添加提交,学生的信息在数据库中就添加完成了,然后再输入填写好的账号和密码进行登录;

(2)图书目录:点击“图书目录”这个菜单,可以查看到系统中所有添加的图书目录,支持通过图书名称、类型、作者等关键词进行查询,如果想要了解某一图书的详细信息,点击后面的“详情”会进入详情查看界面;进行借阅、收藏、点赞、评论等;

(3)我的账户:在前台点击“我的”下面的“我的账户”可以对个人资料+密码修改+自己收藏的信息进行管控。

(4)借阅信息:进入个人中心点击“借阅信息”这个按钮对选中的图书后选择借阅时间、填写借阅天数、次数、说明等信息申请借阅;

(5)归还信息:进入个人中心点击“归还信息”这个按钮,可以进行详情查看和归还操作;

(6)续借信息:进入个人中心点击“续借信息”这个按钮,可以进行详情查看和续借操作;

(7)逾期提醒:进入个人中心点击“逾期提醒”这个按钮,可以进行详情查看逾期信息提醒;

管理员端:

(1)系统用户管理:管理员可以对系统中所有的用户角色进行管控,包含了管理员、以及用户两种角色,如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以查看到了,可以点击用户后面的“删除”按钮直接删除某一用户。

(2)图书目录管理:点击“图书目录管理”这一按钮可以查看到系统当中所有的图书目录,支持通过图书名称进行查询图书目录,如果想要添加新的图书,点击“添加”按钮,然后根据提示填写好图书的具体信息,点击提交所添加的图书目录在数据库就保存下来了,也可以选择要删除的图书直接点击“删除按钮”进行图书删除。

(3)借阅信息管理:进入首页工具栏点击“借阅信息管理”这个按钮可以查看所有借阅信息,可以进行删改查操作之外,还以进行归还操作。

(4)借阅数据管理:进入首页工具栏点击“借阅数据管理”这个按钮可以查看所有借阅数据,可以进行删改查操作。

(5)行为分析管理:进入首页工具栏点击“行为分析管理”这个按钮可以查看所有行为分析,可以进行删改查操作。

(6)归还信息管理:进入首页工具栏点击“归还信息管理”这个按钮可以查看所有归还信息,可以进行删改查等操作。

(7)系统管理:进入后台首页工具栏点击“系统管理”这个按钮可以查看所有轮播图管理等信息,可以进行详情查看、删除、查看评论等操作。

2.2.2 非功能性分析

基于web的图书管理系统的非功能性需求比如基于web的图书管理系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下2-1表格中:

2-1基于web的图书管理系统非功能需求表

安全性

主要指基于web的图书管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。

可靠性

可靠性是指基于web的图书管理系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。

性能

性能是影响基于web的图书管理系统占据市场的必要条件,所以性能最好要佳才好。

可扩展性

比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。

易用性

用户只要跟着基于web的图书管理系统的页面展示内容进行操作,就可以了。

可维护性

基于web的图书管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题

2.3 系统用例分析

基于web的图书管理系统的完整UML用例图分别是图2-1和图2-2。

图2-1 基于web的图书管理系统用户角色用例图

图2-2 基于web的图书管理系统管理员角色用例图

3.4本章小结

本章主要通过对基于web的图书管理系统的可行性分析、功能需求分析、系统用例分析,确定整个基于web的图书管理系统要实现的功能。同时也为基于web的图书管理系统的代码实现和测试提供了标准。

3 基于web的图书管理系统总体设计

本章主要讨论的内容包括基于web的图书管理系统的功能模块设计、数据库系统设计。

3.1系统模块设计

在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本基于web的图书管理系统中的用例。那么接下来就要开始对本基于web的图书管理系统的架构、主要功能和数据库开始进行设计。基于web的图书管理系统根据前面章节的需求分析得出,其总体设计模块图如图3-2所示。

图3-1 基于web的图书管理系统功能模块图

3.2 数据库设计

数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。

3.2.1 数据库概念结构设计

下面是整个基于web的图书管理系统中主要的数据库表总E-R实体关系图。

图3-2 基于web的图书管理系统总E-R关系图

3.3.2 数据库逻辑结构设计

通过上一小节中基于web的图书管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。

表access_token (登陆访问时长)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

用户编号:

表auth (用户权限管理)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间:

表behavior_analysis (行为分析)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

behavior_analysis_id

int

10

0

N

Y

行为分析ID

2

statistical_date

date

10

0

Y

N

统计日期

3

book_types

varchar

64

0

Y

N

图书类型

4

borrowing_frequency

int

10

0

Y

N

0

借阅次数

5

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

6

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表book_catalogue (图书目录)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

book_catalogue_id

int

10

0

N

Y

图书目录ID

2

book_name

varchar

64

0

Y

N

图书名称

3

book_types

varchar

64

0

Y

N

图书类型

4

book_number

varchar

64

0

N

N

图书编号

5

book_cover

varchar

255

0

Y

N

图书封面

6

book_authors

varchar

64

0

Y

N

图书作者

7

publishing_house_name

varchar

64

0

Y

N

出版社名

8

book_introduction

text

65535

0

Y

N

图书简介

9

borrowable_quantity

int

10

0

Y

N

0

可借数量

10

borrowing_fees

int

10

0

Y

N

0

借阅费用

11

borrowing_rules

text

65535

0

Y

N

借阅规则

12

hits

int

10

0

N

N

0

点击数

13

praise_len

int

10

0

N

N

0

点赞数

14

recommend

int

10

0

N

N

0

智能推荐

15

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

16

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表book_types (图书类型)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

book_types_id

int

10

0

N

Y

图书类型ID

2

book_types

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

更新时间

表borrowing_data (借阅数据)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

borrowing_data_id

int

10

0

N

Y

借阅数据ID

2

statistical_date

date

10

0

Y

N

统计日期

3

registered_users

int

10

0

Y

N

0

注册用户

4

borrowed_books

int

10

0

Y

N

0

借阅书量

5

quantity_of_returned_books

int

10

0

Y

N

0

归还书量

6

number_of_books_in_the_library

int

10

0

Y

N

0

馆内书量

7

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

8

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表borrowing_information (借阅信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

borrowing_information_id

int

10

0

N

Y

借阅信息ID

2

borrowing_users

int

10

0

Y

N

0

借书用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

borrowing_date

date

10

0

Y

N

借阅日期

6

book_name

varchar

64

0

Y

N

图书名称

7

book_types

varchar

64

0

Y

N

图书类型

8

book_number

varchar

64

0

Y

N

图书编号

9

borrowing_fees

varchar

64

0

Y

N

借阅费用

10

borrowed_quantity

varchar

64

0

Y

N

借取数量

11

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

12

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表collect (收藏)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间:

表comment (评论)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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:

表hits (用户点击)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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:

表overdue_reminder (逾期提醒)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

overdue_reminder_id

int

10

0

N

Y

逾期提醒ID

2

reminder_date

date

10

0

Y

N

提醒日期

3

reminder_title

varchar

64

0

Y

N

提醒标题

4

reminder_content

text

65535

0

Y

N

提醒内容

5

borrowing_users

int

10

0

Y

N

0

借书用户

6

user_name

varchar

64

0

Y

N

用户姓名

7

user_phone_number

varchar

64

0

Y

N

用户电话

8

borrowing_date

date

10

0

Y

N

借阅日期

9

book_name

varchar

64

0

Y

N

图书名称

10

book_types

varchar

64

0

Y

N

图书类型

11

book_number

varchar

64

0

Y

N

图书编号

12

borrowed_quantity

varchar

64

0

Y

N

借取数量

13

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

14

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表praise (点赞)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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已取消

表regular_users (普通用户)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

regular_users_id

int

10

0

N

Y

普通用户ID

2

user_name

varchar

64

0

Y

N

用户姓名

3

user_gender

varchar

64

0

Y

N

用户性别

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

user_address

varchar

64

0

Y

N

用户地址

6

examine_state

varchar

16

0

N

N

已通过

审核状态

7

user_id

int

10

0

N

N

0

用户ID

8

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

9

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表renewal_information (续借信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

renewal_information_id

int

10

0

N

Y

续借信息ID

2

borrowing_users

int

10

0

Y

N

0

借书用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

renewal_date

date

10

0

Y

N

续借日期

6

book_name

varchar

64

0

Y

N

图书名称

7

book_types

varchar

64

0

Y

N

图书类型

8

book_number

varchar

64

0

Y

N

图书编号

9

borrowed_quantity

varchar

64

0

Y

N

借取数量

10

examine_state

varchar

16

0

N

N

未审核

审核状态

11

examine_reply

varchar

16

0

Y

N

审核回复

12

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

13

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表return_information (归还信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

1

return_information_id

int

10

0

N

Y

归还信息ID

2

borrowing_users

int

10

0

Y

N

0

借书用户

3

user_name

varchar

64

0

Y

N

用户姓名

4

user_phone_number

varchar

64

0

Y

N

用户电话

5

borrowing_date

date

10

0

Y

N

借阅日期

6

book_name

varchar

64

0

Y

N

图书名称

7

book_types

varchar

64

0

Y

N

图书类型

8

book_number

varchar

64

0

Y

N

图书编号

9

borrowing_fees

varchar

64

0

Y

N

借阅费用

10

borrowed_quantity

varchar

64

0

Y

N

借取数量

11

return_date

date

10

0

Y

N

归还日期

12

borrowing_days

int

10

0

Y

N

0

借阅天数

13

total_cost

varchar

64

0

Y

N

总计费用

14

pay_state

varchar

16

0

N

N

未支付

支付状态

15

pay_type

varchar

16

0

Y

N

支付类型: 微信、支付宝、网银

16

create_time

datetime

19

0

N

N

CURRENT_TIMESTAMP

创建时间

17

update_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

更新时间

表slides (轮播图)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间:

表upload (文件上传)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

文件类型

表user (用户账户:用于保存用户登录信息)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

email

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

open_id

varchar

255

0

Y

N

针对获取用户信息字段

14

create_time

timestamp

19

0

N

N

CURRENT_TIMESTAMP

创建时间:

15

vip_level

varchar

255

0

Y

N

会员等级

16

vip_discount

double

11

2

Y

N

0.00

会员折扣

表user_group (用户组:用于用户前端身份和鉴权)

编号

名称

数据类型

长度

小数位

允许空值

主键

默认值

说明

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

更新时间:

3.4本章小结

整个基于web的图书管理系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立E-R模型和数据库逻辑系统设计完成了数据库系统设计。

4 基于web的图书管理系统详细设计与实现

基于web的图书管理系统的详细设计与实现主要是根据前面的基于web的图书管理系统的需求分析和基于web的图书管理系统的总体设计来设计页面并实现业务逻辑。主要从基于web的图书管理系统界面实现、业务逻辑实现这两部分进行介绍。

4.1用户功能模块

4.1.1 前台首页界面

在基于web的图书管理系统的前台首页界面上采用了上+中+下的方式来布局界面,最右上角是登录+注册这+搜索这三个链接,下面依次是导航栏+轮播图以及下面的公告栏,下面依次是推荐的图书商城展示,其主界面展示如下图4-1所示。

图4-1 前台首页界面图

4.1.2 用户注册界面

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

图4-2 前台用户注册界面图

注册代码如下:

    /**

     * 注册

     * @param user

     * @return

     */

    @PostMapping("register")

    public Map<String, Object> signUp(@RequestBody User user) {

        // 查询用户

        Map<String, String> query = new HashMap<>();

        Map<String,Object> map = JSON.parseObject(JSON.toJSONString(user));

        query.put("username",user.getUsername());

        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);

}     

4.1.3 用户登录界面

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

图4-3用户登录界面图

登录代码如下:

/**

     * 登录

     * @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;

        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());

            Duration duration = Duration.ofSeconds(7200L);

            redisTemplate.opsForValue().set(accessToken.getToken(), accessToken,duration);

            // 返回用户信息

            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, "账号或密码不正确");

        }

    }

4.1.4 图书目录列表界面

点击“图书目录”这个菜单,可以查看到系统中所有添加的图书目录,支持通过图书名称、类型、图书作者等关键词进行查询,如果想要了解某一图书的详细信息,点击后面的“详情”会进入详情查看界面;进行借阅、收藏、点赞、评论等;图书目录界面如下图4-4所示。

图4-4 图书目录界面图

4.2管理员功能模块

4.2.1 轮播图管理界面

管理员点击“系统管理”这一菜单会显示轮播图菜单,管理员可以对前台展示的轮播图进行设置。登录界面如下图4-5所示。

图4-5轮播图管理界面图

4.2.2系统用户界面

基于web的图书管理系统中的管理人员是可以对对注册的普通用户进行管理,系统用户界面如下图4-6所示。

图4-6系统用户界面图

4.2.3借阅信息界面

基于web的图书管理系统中的管理人员进入首页工具栏点击“借阅信息管理”这个按钮可以查看所有借阅信息,可以进行删改查操作之外,还以进行提醒、续借、归还操作。借阅信息界面如下图4-7所示。

图4-7借阅信息界面图

4.2.4归还信息界面

基于web的图书管理系统中的管理人员进入首页工具栏点击“归还信息管理”这个按钮可以查看所有归还信息,可以进行支付、删改查等操作。归还信息界面如下图4-8所示。

图4-8归还信息界面图

4.2.5行为分析界面

基于web的图书管理系统中的管理人员进入首页工具栏点击“行为分析管理”这个按钮可以查看所有行为分析,可以进行删改查操作。行为分析界面如下图4-9所示。

图4-9行为分析界面图

5系统测试

5.1 系统测试用例

系统测试包括:用户登录功能测试、用户注册功能测试、图书展示功能测试、图书添加功能测试,密码修改功能测试,如表5-1、5-2、5-3、5-4所示:

用户登录功能测试:

表5-1 用户登录功能测试表

测试名称

测试功能

操作

操作过程

预期结果

测试结果

用户登录模块测试

正确输入用户信息,用户成功登录

输入用户的信息

1.在密码框输入用户密码。2.点击登录

跳转到首页

正确

用户注册功能测试:

表5-2 用户登录功能测试表

测试名称

测试功能

操作

操作过程

预期结果

测试结果

用户注册模块测试

正确输入用户星系,完成用户注册

输入用户的基本信息

在注册页面填写用户相应的信息,然后点击“注册”按钮。

提示成功并跳转到登录界面

正确

用户注册模块测试

用户注册失败

用户两次输入密码不一致

用户在注册页面填写信息时输入两个不一致的密码然后点击“注册”按钮。

注册失败提示两次密码输入不一致

正确

图书目录界面测试:

表5-3 图书目录界面测试表

测试名称

测试功能

操作

操作过程

预期结果

测试结果

图书目录功能模块测试

图书目录正常的显示

浏览图书目录

在前台首页选择一个图书分类进入分类列表,然后选择一个图书

进入该图书的详细信息界面

正确

密码修改功能测试:

表5-4 密码修改功能测试表

用例名称

密码修改测试用例

目的

测试管理员密码修改功能

前提

管理员用户正常登录情况下

测试流程

1)管理员密码修改并完成填写。

2)点击进行提交。

预期结果

使用新的密码可以登录

实际结果

实际结果与预期结果一致

5.2 系统测试结果

通过编写基于web的图书管理系统的测试用例,已经检测完毕用户登录模块、用户注册模块、图书分类展示模块、图书添加、修改密码模块功能测试,通过这4大模块为基于web的图书管理系统的后期推广运营提供了强力的技术支撑。

                                                                   结论

经过对基于Web的图书管理系统的深入研究与实践,我们得出的结论不仅凸显了其在图书馆管理中的显著优势,还预示了其未来发展的巨大潜力。

首先,该系统彻底改变了传统图书管理的模式,通过在线管理、自动化借阅流程等创新功能,极大地提升了图书馆的工作效率。图书馆员能够更高效地处理图书的入库、分类、检索和借阅等任务,为读者提供更为迅速、准确的服务。同时,读者也能通过该系统方便地查询图书信息、预约借阅、续借图书等,极大地提高了他们的满意度和便利性。

其次,基于Web的图书管理系统为图书馆服务带来了质的飞跃。通过集成先进的技术手段,如大数据分析、人工智能等,该系统能够深入分析读者的借阅行为和偏好,为他们提供个性化的图书推荐和阅读建议。这种智能化的服务模式不仅提升了用户体验,还有助于图书馆更好地了解读者需求,优化图书资源的配置和采购策略。

此外,该系统还具有良好的易用性和可扩展性。友好的用户界面和简洁的操作流程使得用户能够轻松上手,而灵活的系统架构和开放的API接口则使得系统能够方便地与其他系统和应用进行集成和扩展。这为图书馆未来的数字化转型和创新发展提供了有力的技术支撑。

综上所述,基于Web的图书管理系统不仅为图书馆管理带来了显著的改进和效益,还展示了其未来发展的巨大潜力。随着技术的不断进步和图书馆需求的日益增长,我们有理由相信该系统将继续在图书馆事业中发挥重要作用,推动图书馆向更加智能化、高效化、个性化的方向发展。

                                                             参考文献

  • [1]Lestiyani A ,Joko T ,Holford P , et al. Natural Infection of Murraya paniculata and Murraya sumatrana with CLas in Java. [J]. Plant disease, 2024,
  • [2]Ramadani W S ,Antriyandarti E ,Qonita A R R . Efficiency of rice farming in flood-prone areas of East Java, Indonesia [J]. Open Agriculture, 2024, 9 (1):
  • [3]万志强. 基于Java语言的地铁数据库网站设计与实现 [J]. 现代信息科技, 2024, 8 (07): 25-29. DOI:10.19850/j.cnki.2096-4706.2024.07.006.
  • [4]赵彩霞,张栽培,杨璇. 基于Java编程导航学习平台开发设计的研究 [J]. 家电维修, 2024, (03): 62-64.
  • [5]张建兵,方紫玉. 混合式教学模式下Java语言程序设计过程性考核实践探索 [J]. 电脑知识与技术, 2024, 20 (07): 168-170. DOI:10.14004/j.cnki.ckt.2024.0431.
  • [6]单厚信,刘舒心,程文远,等. 基于SSM架构的图书资料管理系统设计与实现 [J]. 现代信息科技, 2023, 7 (23): 46-51. DOI:10.19850/j.cnki.2096-4706.2023.23.010.
  • [7]严明,边建军. 动态书目推荐图书管理系统设计与实现 [J]. 福建电脑, 2023, 39 (11): 87-92. DOI:10.16707/j.cnki.fjpc.2023.11.018.
  • [8]杨静,梁益铭,左斯敏,等. 中山大学智能图书管理系统建设与应用 [J]. 中国教育网络, 2023, (11): 75-77.
  • [9]李大志. Java Web在高校图书管理系统中的应用研究 [J]. 中国信息化, 2023, (06): 64-65.
  • [10]周伟. 基于图书管理系统的大数据应用研究 [J]. 网络安全技术与应用, 2023, (05): 71-73.
  • [11]Yang Y . Design and Implementation of Student Information Management System Based on Springboot [J]. Advances in Computer, Signals and Systems, 2022, 6 (6):
  • [12]刘源昭,陈伟,曹俊杰,等. 基于SSM架构的图书管理系统 [J]. 山西电子技术, 2022, (03): 61-63+76.
  • [13]李丹. 工程教育认证背景下案例式翻转课堂设计——以基于Android系统的图书管理系统设计为例 [J]. 北部湾大学学报, 2022, 37 (02): 63-71. DOI:10.19703/j.bbgu.2096-7276.2022.02.0063.
  • [14]张俊,潘文军. 攀枝花学院图书管理系统的设计与实现 [J]. 电脑知识与技术, 2022, 18 (10): 63-64. DOI:10.14004/j.cnki.ckt.2022.0786.
  • [15]王佳珺. 基于Java的校园图书管理系统程序设计 [J]. 电脑知识与技术, 2022, 18 (08): 60-61+64. DOI:10.14004/j.cnki.ckt.2022.0480.
  • [16]孙婷婷,邱宏. 基于图书管理系统在中小型图书馆使用的思考 [J]. 信息记录材料, 2022, 23 (01): 89-91. DOI:10.16009/j.cnki.cn13-1295/tq.2022.01.035.
  • [17]尹慧,段华琼. 基于C语言的图书管理系统的设计与实现 [J]. 信息与电脑(理论版), 2021, 33 (23): 116-118.
  • [18]胡素娟. 基于Java图书管理系统的设计与实现 [J]. 信息记录材料, 2021, 22 (12): 161-163. DOI:10.16009/j.cnki.cn13-1295/tq.2021.12.044.
  • [19]罗莉霞,高何裕. 基于B/S的高校图书管理与个性化推荐系统的设计与实现 [J]. 技术与市场, 2021, 28 (11): 184-185.
  • [20]黄波. 基于PHP+MySQL图书管理系统设计与实现 [J]. 信息与电脑(理论版), 2021, 33 (19): 124-126.
  • [21]Cheng F . Talent Recruitment Management System for Small and Micro Enterprises Based on Springboot Framework [J]. Advances in Educational Technology and Psychology, 2021, 5 (2):
  • [22]Chen J ,Jian C ,Hailan P . Design of Man Hour Management Information System on SpringBoot Framework [J]. Journal of Physics: Conference Series, 2020, 1646 (1): 012136-.

                                                              致  谢

在结束对基于Web的图书管理系统的研究与设计之际,我衷心地向所有支持和帮助过我的人们表示深深的感谢。首先,我要感谢我的导师,是他们悉心的指导和无私的奉献,让我在学术道路上不断前进。他们的专业知识、严谨态度和敬业精神,不仅让我受益良多,更是我今后学习和工作的楷模。

同时,我要感谢我的团队成员,是大家的共同努力和协作,使得这个项目能够顺利完成。每一个成员都在自己的岗位上发挥出了重要作用,为系统的设计和开发贡献了智慧和力量。我们的团结合作,不仅增强了团队的凝聚力,也为我们今后的工作打下了坚实的基础。

此外,我还要感谢图书馆的工作人员和读者们。他们的实际需求和使用反馈,为我们提供了宝贵的改进方向和建议。正是他们的支持和信任,让我们有动力不断完善和优化系统,为图书馆提供更好的服务。

最后,我要感谢所有关心和帮助过我的人,包括我的家人、朋友和同学们。他们的支持和鼓励,让我在困难时能够坚持下去,在成功时能够分享喜悦。我会珍惜这份情谊,并以此为动力,继续前行。

再次感谢所有给予我帮助和支持的人,谢谢你们!

                                          点赞+收藏+关注 → 私信领取本源代码、数据库
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值