目 录
摘要
Abstract
1 绪论
1.1 研究背景及意义
1.2国内外研究现状
1.3 论文结构与章节安排
2 白云图书管理系统系统分析
2.1 系统可行性分析
3.2.1 技术可行性
3.2.2 经济可行性
3.2.3 操作可行性
2.2 系统功能分析
2.2.1 功能性分析
2.2.2 非功能性分析
2.3 系统用例分析
3.4本章小结
3 白云图书管理系统总体设计
3.1系统模块设计
3.2 数据库设计
3.2.1 数据库概念结构设计
3.3.2 数据库逻辑结构设计
3.4本章小结
4 白云图书管理系统详细设计与实现
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图书归还界面
5系统测试
5.1 系统测试用例
5.2 系统测试结果
结论
参考文献
致 谢
摘要
大数据时代下,数据呈爆炸式地增长。为了迎合信息化时代的潮流和信息化安全的要求,利用互联网服务于其他行业,促进生产,已经是成为一种势不可挡的趋势。在图书管理系统的要求下,开发一款整体式结构的白云图书管理系统,将复杂的系统进行拆分,能够实现对需求的变化快速响应、系统稳定性的保障,能保证平台可持续、规模化发展的要求。
此白云图书管理系统的开发项目采用Java开发语言,数据使用的是MYSQL,系统就论题的各类需求分析说明做出解释,然后再就系统的总体设计和详细设计做出论述,给出了系统总体结构的搭建方法。从而满足大部分中小型电子商务网站的需求。
关键词:白云图书管理系统;Java;Hadoop框架.;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, it has become an irresistible trend to use the Internet to serve other industries and promote production. Under the requirements of the library management system, develop a comprehensive structure of the Baiyun Library Management System, which breaks down complex systems and can quickly respond to changes in requirements, ensuring system stability, and meeting the requirements of sustainable and large-scale development of the platform.
The development project of this Baiyun Library Management System adopts Java development language and uses MYSQL for data. The system provides explanations for various requirements analysis 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. So as to meet the needs of most small and medium-sized e-commerce websites.
Keywords:Baiyun Library Management System; Java; Hadoop Framework; MYSQL database
1 绪论
1.1 研究背景及意义
(1)管理员通过数据库管理和维护系统可以对借阅者和图书进行管理和维护。管理员可以对后台数据中的信息进行删除、修改、更新等基本操作以管理和维护借阅者信息。
(2)用户可以通过图书作者、图书名、ISBN、出版社、主题词、图书书号进行查询,以便用户对图书信息的快速检索。
(3)图书的添加,新书的出版可以及时的输入数据库以待取用,已经报废的旧书及时的删除或禁用。
(4)借阅者可以在线随时查询图书信息,借阅图书,等待管理员审核通过。
1.2国内外研究现状
1.3 论文结构与章节安排
论文将分层次经行编排,除去论文摘要致谢文献参考部分,正文部分还会对网站需求做出分析,以及阐述大体的设计和实现的功能,最后罗列部分调测记录,论文主要架构如下:
第一章:引言。第一章主要介绍了课题研究的背景,研究意义和本文的主要工作。
第二章:系统需求分析。第二章主要从系统的用户、功能等方面进行需求分析。
第三章:系统设计。第三章主要对系统框架、系统功能模块、数据库进行功能设计。
第四章:系统实现。第四章主要介绍了系统框架搭建、系统界面的实现。
第五章:系统测试。第五章主要对系统的部分界面进行测试并对主要功能进行测试
第六章:总结。
2 白云图书管理系统系统分析
本章内容概括了白云图书管理系统的可行性分析、功能分析以及用例分析。
2.1 系统可行性分析
3.2.1 技术可行性
本系统采取的是目前应用最广泛的程序进行技术的支持,主要的技术支持是java语言,他作为一个相当成熟的语言程序,在众多的软件开发中起着很大作用。而且用java语言编辑出来程序可以直接运行,不需要借助其他的翻译器进行翻译。所以在技术方面是完全可以行的。
3.2.2 经济可行性
本项目开发的初衷就是为了节约,因为系统开发的所有过程都是我自己开发的,而且在开发过程使用到的技术也都是市面上常见的容易操作的,所以不需要请专业的人士花资金来进行系统的开发,而且在项目开发的过程中我也学到了更多的知识。开发的这个软件可以在网络中进行免费的下载,对计算机的软硬件没有很高的要求,因此这个项目是非常实惠的,在经济方面是完全可性的。
3.2.3 操作可行性
操作可行性也就是系统的可用性,一个系统的操作是否容易决定着这个系统的使用度,在系统的操作方面的设计我都是采取简洁易懂的方式,操作的整个菜单界面整齐有序,所有的功能都有序的排列,不会出现重叠或者需要转换的现象,用户想要哪方面的操作都可以直接进行操作,所以该系统任何人都可以进行操作,不需要有相关专业的技术这样用户在操作起来就容易很多。
2.2 系统功能分析
2.2.1 功能性分析
白云图书管理系统我划分为了用户管理模块和管理员模块这两大部分。
(1)注册登录:当用户想要对系统中所实现的功能进行查询管理的时候,就必须进行登录到系统当中,如果没有账号的话,在登录界面,点击“注册”按钮就会跳转到注册的界面,根据提示填写好注册信息,添加提交,学生的信息在数据库中就添加完成了,然后再输入填写好的账号和密码进行登录;
(2)图书信息:点击“图书信息”这个菜单,可以查看到系统中所有添加的图书信息,支持通过图书名称、类别、作者等关键词进行查询,如果想要了解某一图书的详细信息,点击后面的“详情”会进入详情查看界面;可以进行借阅+点赞+评论+收藏等。
(3)图书借阅:进入个人中心点击“图书借阅”这个按钮对选中的图书后选择借阅时间、填写借阅天数、次数、说明等信息申请借阅;
(4)图书归还:进入个人中心点击“图书借阅”这个按钮已借阅的图书进行详情查看和归还操作;
(5)我的账户:在前台点击“我的”下面的“我的账户”可以对个人资料+密码修改+自己收藏的信息进行管控。
管理员端:
(1)系统用户管理:管理员可以对系统中所有的用户角色进行管控,包含了管理员、以及用户两种角色,如果需要添加新的用户,点击页面中的“添加”按钮根据提示输入上用户信息,点击“提交”以后在对应的用户界面就可以查看到了,可以点击用户后面的“删除”按钮直接删除某一用户。
(2)图书信息管理:点击“图书信息管理”这一按钮可以查看到系统当中所有的图书信息,支持通过图书名称进行查询图书信息,如果想要添加新的图书,点击“添加”按钮,然后根据提示填写好图书的具体信息,点击提交所添加的图书信息在数据库就保存下来了,也可以选择要删除的图书直接点击“删除按钮”进行图书删除。
(3)图书借阅管理:进入首页工具栏点击“借阅管理”这个按钮可以查看所有借阅信息,可以进行删改查操作之外,还以进行归还操作。
(4)图书归还管理:进入首页工具栏点击“归还管理”这个按钮可以查看所有归还信息,可以进行删改查等操作。
(5)通知公告管理:点击“通知公告管理”这个菜单,可以查看到系统中所有添加的通知公告信息,支持通过标题对通知公告信息进行查询,添加、删除等操作。
(6)系统管理:进入后台首页工具栏点击“系统管理”这个按钮可以查看所有轮播图信息,可以进行详情查看、删除、查看评论等操作。
(7)个人信息:管理员和用户点击“个人信息”按钮,可以对个人的头像、昵称、手机号码等信息进行更新。
(8)修改密码:管理员和用户点击“修改密码”按钮,可以对登录密码进行更改,首先输入原密码,然后再输入新密码和确认密码,当原密码正确,输入两次新密码一致,则修改成功,否则给出错误提示信息。
2.2.2 非功能性分析
白云图书管理系统的非功能性需求比如白云图书管理系统的安全性怎么样,可靠性怎么样,性能怎么样,可拓展性怎么样等。具体可以表示在如下3-1表格中:
表3-1白云图书管理系统非功能需求表
安全性 | 主要指白云图书管理系统数据库的安装,数据库的使用和密码的设定必须合乎规范。 |
可靠性 | 可靠性是指白云图书管理系统能够安装用户的指示进行操作,经过测试,可靠性90%以上。 |
性能 | 性能是影响白云图书管理系统占据市场的必要条件,所以性能最好要佳才好。 |
可扩展性 | 比如数据库预留多个属性,比如接口的使用等确保了系统的非功能性需求。 |
易用性 | 用户只要跟着白云图书管理系统的页面展示内容进行操作,就可以了。 |
可维护性 | 白云图书管理系统开发的可维护性是非常重要的,经过测试,可维护性没有问题 |
2.3 系统用例分析
白云图书管理系统的完整UML用例图分别是图2-1和图2-2。
图2-1 白云图书管理系统用户角色用例图
3.4本章小结
本章主要通过对白云图书管理系统的可行性分析、功能需求分析、系统用例分析,确定整个白云图书管理系统要实现的功能。同时也为白云图书管理系统的代码实现和测试提供了标准。
3 白云图书管理系统总体设计
本章主要讨论的内容包括白云图书管理系统的功能模块设计、数据库系统设计。
3.1系统模块设计
在上一章节中主要对系统的功能性需求和非功能性需求进行分析,并且根据需求分析了本白云图书管理系统中的用例。那么接下来就要开始对本白云图书管理系统的架构、主要功能和数据库开始进行设计。白云图书管理系统根据前面章节的需求分析得出,其总体设计模块图如图3-2所示。
图3-1 白云图书管理系统功能模块图
3.2 数据库设计
数据库设计一般包括需求分析、概念模型设计、数据库表建立三大过程,其中需求分析前面章节已经阐述,概念模型设计有概念模型和逻辑结构设计两部分。
3.2.1 数据库概念结构设计
下面是整个白云图书管理系统中主要的数据库表总E-R实体关系图。
图3-2 白云图书管理系统总E-R关系图
3.3.2 数据库逻辑结构设计
通过上一小节中白云图书管理系统中总E-R关系图上得出一共需要创建很多个数据表。在此我主要罗列几个主要的数据库表结构设计。
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 更新时间: |
表book_borrowing (图书借阅)
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_borrowing_id | int | 10 | 0 | N | Y | 图书借阅ID | |
2 | regular_users | int | 10 | 0 | Y | N | 0 | 普通用户 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
5 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
6 | borrowed_quantity | int | 10 | 0 | Y | N | 0 | 借阅数量 |
7 | borrowing_days | int | 10 | 0 | Y | N | 0 | 借阅天数 |
8 | borrowing_date | datetime | 19 | 0 | Y | N | 借阅日期 | |
9 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
10 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_categories_id | int | 10 | 0 | N | Y | 图书类别ID | |
2 | book_categories | 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 | book_information_id | int | 10 | 0 | N | Y | 图书信息ID | |
2 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
3 | book_categories | varchar | 64 | 0 | Y | N | 图书类别 | |
4 | book_cover | varchar | 255 | 0 | Y | N | 图书封面 | |
5 | book_authors | varchar | 64 | 0 | Y | N | 图书作者 | |
6 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
7 | publishing_house_name | varchar | 64 | 0 | Y | N | 出版社名 | |
8 | publication_date | date | 10 | 0 | Y | N | 出版日期 | |
9 | book_inventory | int | 10 | 0 | Y | N | 0 | 图书库存 |
10 | book_introduction | text | 65535 | 0 | Y | N | 图书简介 | |
11 | hits | 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 | regular_users | int | 10 | 0 | Y | N | 0 | 普通用户 |
3 | user_name | varchar | 64 | 0 | Y | N | 用户姓名 | |
4 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
5 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
6 | return_quantity | int | 10 | 0 | Y | N | 0 | 归还数量 |
7 | return_date | datetime | 19 | 0 | Y | N | 归还日期 | |
8 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
9 | update_time | timestamp | 19 | 0 | N | N | CURRENT_TIMESTAMP | 更新时间 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
1 | book_storage_id | int | 10 | 0 | N | Y | 图书入库ID | |
2 | book_name | varchar | 64 | 0 | Y | N | 图书名称 | |
3 | book_categories | varchar | 64 | 0 | Y | N | 图书类别 | |
4 | book_number | varchar | 64 | 0 | Y | N | 图书编号 | |
5 | inventory_quantity | int | 10 | 0 | Y | N | 0 | 入库数量 |
6 | storage_time | date | 10 | 0 | Y | N | 入库时间 | |
7 | create_time | datetime | 19 | 0 | N | N | CURRENT_TIMESTAMP | 创建时间 |
8 | 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 | 更新时间: |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | 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已取消 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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 | contact_information | 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 | 更新时间 |
表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 | | 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 | 会员折扣 |
编号 | 名称 | 数据类型 | 长度 | 小数位 | 允许空值 | 主键 | 默认值 | 说明 |
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本章小结
整个白云图书管理系统的需求分析主要对系统总体架构以及功能模块的设计,通过建立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.2.2通知公告界面
白云图书管理系统中的管理人员是可以对网站发布的公告进行管控,通知公告界面如下图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 图书信息界面测试表
测试名称 | 测试功能 | 操作 | 操作过程 | 预期结果 | 测试结果 |
图书信息功能模块测试 | 图书信息正常的显示 | 浏览图书信息 | 在前台首页选择一个图书分类进入分类列表,然后选择一个图书 | 进入该图书的详细信息界面 | 正确 |
5.2 系统测试结果
通过编写白云图书管理系统的测试用例,已经检测完毕用户登录模块、用户注册模块、图书分类展示模块、图书添加模块功能测试,通过这4大模块为白云图书管理系统的后期推广运营提供了强力的技术支撑。
结论
至此,白云图书管理系统已经结束,在开发前做了许多的准备,在本系统的设计和开发过程中阅览和学习了许多文献资料,从中我也收获了很多宝贵的方法和设计思路,对系统的开发也起到了很重要的作用,系统的开发技术选用的都是自己比较熟悉的,比如Web、Java技术、MYSQL,这些技术都是在以前的学习中学到了,其中许多的设计思路和方法都是在以前不断地学习中摸索出来的经验,其实对于我们来说工作量还是比较大的,但是正是由于之前的积累与准备,才能顺利的完成这个项目,由此看来,积累经验跟做好准备是十分重要的事情。
当然在该系统的设计与实现的过程中也离不开老师以及同学们的帮助,正是因为他们的指导与帮助,我才能够成功的在预期内完成了这个系统。同时在这个过程当中我也收获了很多东西,此系统也有需要改进的地方,但是由于专业知识的浅薄,并不能做到十分完美,希望以后有机会可以让其真正的投入到使用之中。
参考文献
- [1]Savita C ,V. K ,R. S , et al. Parametrized Optimization Based on an Investigation of Musical Similarities Using SPARK and Hadoop [J]. SN Computer Science, 2023, 5 (1):
- [2]任宏,李春林,李晓峰. 基于Hadoop技术的物联网大数据同步存储系统设计 [J]. 网络安全和信息化, 2023, (12): 85-87.
- [3]那蓉萃. 基于Hadoop的工业物联网大数据处理及应用 [J]. 信息记录材料, 2023, 24 (12): 221-223+226. DOI:10.16009/j.cnki.cn13-1295/tq.2023.12.061.
- [4]严明,边建军. 动态书目推荐图书管理系统设计与实现 [J]. 福建电脑, 2023, 39 (11): 87-92. DOI:10.16707/j.cnki.fjpc.2023.11.018.
- [5]刘宇. 基于Hadoop的智能调度云数据中心关键技术探析 [J]. 电气技术与经济, 2023, (09): 310-312+318.
- [6]杨静,梁益铭,左斯敏等. 中山大学智能图书管理系统建设与应用 [J]. 中国教育网络, 2023, (11): 75-77.
- [7]S. J M ,T. S . Performance Improvement through Novel Adaptive Node and Container Aware Scheduler with Resource Availability Control in Hadoop YARN [J]. School of Computer Science and Engineering, Vellore Institute of Technology , Chennai, 600127 , India, 2023, 47 (3): 3083-3108.
- [8]石文昭. 基于Hadoop的自动化设备监管系统设计 [J]. 信息记录材料, 2023, 24 (11): 178-180. DOI:10.16009/j.cnki.cn13-1295/tq.2023.11.025.
- [9]朱红梅. 信息化背景下高校图书管理创新研究——以新公共管理理论为视角 [J]. 武汉纺织大学学报, 2023, 36 (05): 88-91.
- [10]Soudabeh H ,Neda M ,Tobias O , et al. MapReduce scheduling algorithms in Hadoop: a systematic study [J]. Journal of Cloud Computing, 2023, 12 (1):
- [11]王子昱. 基于Hadoop的大数据云计算处理的实现 [J]. 无线互联科技, 2023, 20 (19): 89-91+104.
- [12]赵迎霞. 高校图书管理工作实效性提升研究 [J]. 产业与科技论坛, 2023, 22 (19): 285-286.
- [13]刘媛媛. 基于Hadoop技术的互联网舆情监测处理平台的设计——以易班平台为视角 [J]. 数字技术与应用, 2023, 41 (09): 196-198. DOI:10.19695/j.cnki.cn12-1369.2023.09.61.
- [14]邹文景,唐良运,甘莹等. 基于Hadoop技术的物联网大数据同步存储系统设计 [J]. 电子设计工程, 2023, 31 (18): 114-117+122. DOI:10.14022/j.issn1674-6236.2023.18.024.
- [15]Shengting M ,Shanshan Z . Map vector tile construction for arable land spatial connectivity analysis based on the Hadoop cloud platform [J]. Frontiers in Earth Science, 2023, 11
- [16]时业茂,颜晓宏,刘卫. 基于Spring Boot整合SSMP框架实现图书管理系统 [J]. 电脑编程技巧与维护, 2023, (06): 82-84. DOI:10.16184/j.cnki.comprg.2023.06.044.
- [17]周伟. 基于图书管理系统的大数据应用研究 [J]. 网络安全技术与应用, 2023, (05): 71-73.
- [18]赵冰. 计算机管理系统在校园图书馆中的应用 [J]. 电子技术, 2023, 52 (03): 250-251.
- [19]陈伟. 信息化背景下图书管理的主要问题及对策探讨 [J]. 兰台内外, 2023, (08): 64-66.
- [20]何辉娟. 基于大数据的智能图书管理系统的研究与设计 [J]. 电子技术与软件工程, 2023, (06): 222-225.
- [21]陈艳,鲁苗苗. 高校图书管理工作强化措施 [J]. 文化产业, 2023, (02): 103-105.
- [22]Jennifer B . Learning management systems and online tools to support continuous workplace learning in academic libraries [J]. ADVANCES IN ONLINE EDUCATION, 2023, 1 (4): 346-356.
- [23]Yuqing S . Application of FCM Clustering Algorithm in Digital Library Management System [J]. Electronics, 2022, 11 (23): 3916-3916.
- [24]孙尊芳,宋丹丹. 图书管理与服务中大数据技术应用研究 [J]. 文化产业, 2022, (27): 112-114.
- [25]徐建林. 基于JSP的图书馆管理系统的设计与实现 [J]. 长江信息通信, 2022, 35 (08): 143-145.
致 谢
光阴似箭,一晃大学生活即将过去了。一直以严谨的态度和积极的热情投身于学习和工作中,虽然有竞争,也有泪水,但是通过我不断学习和奋斗不断的完善自己,不仅很好的完成了我的学业而且也让我的各方面得到了发展,取得了很大的进步。
大学的生活也即将结束,虽然也有许多的不舍,但是终究是要告别的。回想大学的学习生活,有泪水也有汗水。在此期间我严格要求自己,凭着对知识的强烈追求,刻苦钻研,勤奋好学,态度端正,目标明确,牢固的掌握了一些专业知识和技能,做到了理论联系实际。除了专业知识的学习外,我还不断的扩展我的知识面,从不同的领域以不同的方式来获得新的知识。争取成为一名各方面都很合格的大学生。
这次的毕业设计,是我独自完成周期最长,也是耗力最大的一个项目。值得庆幸的是,在我毕业设计完成的过程当中,有许多帮助我的同学和老师。在几个月的开发过程中,我遇到了大大小小无数个问题。是我的舍友和老师,不断地帮助鼓励。
我的指导老师,在自身工作十分繁忙的情况下,依然能做到及时恢复我们发去的问题邮件,并抽时间对我们进行线下的辅导。指出我们设计上的失误,逻辑错误以及产品力规划问题,可以说没有导师的帮助,我的毕设会陷入死胡同,是导师为我指点了迷津,像迷雾中的路灯,为我指明方向!