智能图书馆开源项目

news2024/9/20 16:34:02

结尾有项目链接

技术栈介绍

☃️前端主要技术栈

技术作用版本
Vue提供前端交互2.6.14
Vue-Router路由式编程导航3.5.1
Element-UI模块组件库,绘制界面2.4.5
Axios发送ajax请求给后端请求数据1.2.1
core-js兼容性更强,浏览器适配3.8.3
swiper轮播图插件(快速实现)3.4.2
vue-baberragevue弹幕插件(实现留言功能)3.2.4
vue-json-excel表格导出Excel0.3.0
html2canvas+jspdf表格导出PDF1.4.1 2.5.1
node-polyfill-webpack-pluginwebpack5中移除了nodejs核心模块的polyfill自动引入2.0.1
default-passive-eventsChrome 增加了新的事件捕获机制 Passive Event Listeners(被动事件侦听器)让页面滑动更加流畅,主要用于提升移动端滑动行为的性能
nprogress发送请求显示进度条(人机交互友好)0.2.0
echarts数据转图标的好工具(功能强大)5.4.1
less lessloader方便样式开发4.1.3 11.1.0

☃️后端主要技术栈

技术及版本作用版本
SpringBoot应用开发框架2.7.8
JDKJava 开发包1.8
MySQL提供后端数据库8.0.23
MyBatisPlus提供连接数据库和快捷的增删改查3.5.1
SpringBoot-Configuration-processor配置处理器 定义的类和配置文件绑定一般没有提示,因此可以添加配置处理器,产生相对应的提示.
SpringBoot-Starter-Web后端集成Tomcat MVC用于和前端连接
SpringBoot-starter-testJunit4单元测试前端在调用接口前,后端先调用单元测试进行增删改查,注意Junit4和5的问题,注解@RunWith是否添加
Lombok实体类方法的快速生成 简化代码
mybatis-plus-generator代码生成器3.5.1
MyBatisXMyBatisPlus插件直接生成mapper,实体类,service
jjwttoken工具包0.9.0
fastjson阿里巴巴的json对象转化工具1.2.83
hutoolhutool工具包(简化开发工具类)文档

☀️架构

图书管理系统架构图

☀️项目简介

  • 主要使用Vue2和SpringBoot2实现

  • 项目权限控制分别为:用户借阅,图书管理员,系统管理员

  • 开发工具:IDEA2022.1.3(真不推荐用eclipse开发,IDEA项目可以导出为eclipse项目,二者不影响,但需要自己学教程)

  • 学校老师硬性要求软件的话,还是按要求来。可以先问一下是否可以选择其他软件开发。

  • 用户账号密码: 相思断红肠 123456

  • 图书管理员账号密码: admin 123456

  • 系统管理员账号密码: root 123456

  • 前端样式参考 感谢原作者明月复苏

☀️项目详细介绍(亮点)

  • 本项目采用前后端分离的模式,前端构建页面,后端作数据接口,前端调用后端数据接口得到数据,重新渲染页面。
  • 后端已开启CORS跨域支持
  • API认证使用Token认证
  • 前端在Authorization字段提供token令牌
  • 使用HTTP Status Code表示状态
  • 数据返回格式使用JSON
  • 后端采用权限拦截器进行权限校验,并检查登录情况
  • 添加全局异常处理机制,捕获异常,增强系统健壮性
  • 前端用Echarts可视化库实现了图书借阅的分析图标(折线图、饼图),并通过loading配置提高加载体验。
  • 留言组件采用弹幕形式,贴合用户的喜好。
  • 引入knife4j依赖,使用 Swagger + Knife4j 自动生成 OpenAPI 规范的接口文档,前端可以在此基础上使用插件自动生成接口请求代码,降低前后端协作成本
  • 使用ElementUI组件库进行前端界面搭建,快速实现页面生成,并实现了前后端统一权限管理,多环境切换等能力。
  • 基于MyBatis Plus框架的QueryWrapper实现对MySQL数据库的灵活查询,并配合MyBatisX插件自动生成后端CRUD基础代码,减少重复工作。

⭐用户模块功能介绍

image-20231030110244726

  • 图书查询功能:分页构造器缓解数据过大压力,后端可设置请求数防止爬虫请求数过大,服务器负载过大。模糊查询进行字段搜索。表格均可导出PDF和EXCEL。

  • 读者规则功能:查询现有的借阅规则,借阅规则包括:借阅编号,可借阅图书数量,可借阅天数,可借阅图书馆,过期扣费/天。

  • 查看公告: 可以查询图书管理员发布的公告列表,文字滑动⭐

  • 个人信息: 可以查看个人的借阅证编号,借阅证姓名,规则编号,状态,可以修改个人账户的密码。

  • 借阅信息: 可以查看自身借阅过的图书记录和归还情况

  • 违章信息: 可以查询自身归还的图书是否有违章信息

  • 读者留言: 实现留言功能并以弹幕形式显示

⭐图书管理员模块功能介绍

image-20231030110256051

  • 借阅图书: 图书管理员输入借阅证号(用户)和要借的图书编号和当前的时间,点击借阅。

  • 归还图书: 输入图书编号查看图书是否逾期,并且可以设置违规信息,然后选择是否归还图书

  • 借书报表: 用于查询已经借阅并归还的书籍列表,同样使用分页构造器和模糊查询字段,显示借阅证编号,图书编号,借阅日期,截止日期,归还日期,违章信息,处理人。

  • 还书报表: 用于查询已经借阅但是还未归还的书籍列表,显示借阅证编号,图书编号,借阅日期,截止日期。

  • 发布公告: 可以查询当前发布的公告列表,并进行删除,修改,增加功能,分页构造器用于缓解数据量大的情况。

⭐系统管理员模块功能介绍

image-20231030110303880

  • 书籍管理: 可以查询当前的所有图书,显示图书编号,图书昵称,作者,图书馆,分类,位置,状态,描述。可以进行添加,修改,删除图书。利用分页构造器实现批量查询。利用模糊查询实现图书搜索功能。利用插件实现PDF和EXCEL导出。
  • 书籍类型: 显示查询当前的所有图书类型,可以进行添加,修改,删除图书类型,利用分页构造器实现批量查询,缓解数据压力。
  • 借阅证管理: 可以查询当前的所有借阅证列表,也就是用户数量,可以进行添加,修改,删除操作。同样实现分页。
  • 借阅信息查询: 可以查询当前已经完成借阅和归还的记录,显示借阅证号,书籍编号,借阅日期,截止日期,归还日期,违章信息,处理人。分页功能,PDF和EXCEL导出。
  • 借阅规则管理: 可以查询当前所有的借阅规则,显示限制借阅天数,限制本数,限制图书馆,逾期费用,可以进行添加、删除、修改操作。
  • 图书管理员管理: 显示当前的图书管理员列表,显示账号,姓名,邮箱,可以进行添加、删除、修改操作。
  • 系统管理: 可以查询一个月内的借阅量,以一周为时间间隔,计算借阅量,用Echarts实现折线图的展示。

☀️数据库表设计

t_users表

列名数据类型以及长度备注
user_idint(11)主键 非空 自增 用户表的唯一标识
usernamevarchar(32)用户名 非空
passwordvarchar(32)密码(MD5加密) 非空
card_namevarchar(10)真实姓名 非空
card_numberBigint(11)借阅证编号 固定 11位随机生成 非空(后文都改BigInt)
rule_numberint(11)规则编号 可以自定义 也就是权限功能
statusint(1)1表示可用 0表示禁用
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_admins表

列名数据类型以及长度备注
admin_idint(11)主键 非空 自增 管理员表的唯一标识
usernamevarchar(32)用户名 非空
passwordvarchar(32)密码(MD5加密) 非空
admin_namevarchar(10)管理员真实姓名 非空
statusint(1)1表示可用 0表示禁用
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_book_admins表

列名数据类型以及长度备注
book_admin_idint(11)主键 非空 自增 管理表的唯一标识
usernamevarchar(32)用户名 非空
passwordvarchar(32)密码(MD5加密)非空
book_admin_namevarchar(10)图书管理员真实姓名 非空
statusint(1)1表示可用 0表示禁用
emailvarchar(255)电子邮箱
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_books表

列名数据类型以及长度备注
book_idint(11)主键 自增 非空 图书表的唯一标识
book_numberint(11)图书编号 非空 图书的唯一标识
book_namevarchar(32)图书名称 非空
book_authorvarchar(32)图书作者 非空
book_libraryvarchar(32)图书所在图书馆的名称 非空
book_typevarchar(32)图书类别 非空
book_locationvarchar(32)图书位置 非空
book_statusvarchar(32)图书状态(未借出/已借出)
book_descriptionvarchar(100)图书描述
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_books_borrow表

列名数据类型以及长度备注
borrow_idint(11)主键 自增 非空 借阅表的唯一标识
card_numberint(11)借阅证编号 固定 11位随机生成 非空 用户与图书关联的的唯一标识
book_numberint(11)图书编号 非空 图书的唯一标识
borrow_datedatetime借阅日期 Java注解 JsonFormatter
close_datedatetime截止日期 Java注解 JsonFormatter
return_datedatetime归还日期 Java注解 JsonFormatter
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_notice表

列名数据类型以及长度备注
notice_idint(11)主键 非空 自增 公告表记录的唯一标识
notice_titlevarchar(32)公告的题目 非空
notice_contentvarchar(255)公告的内容 非空
notice_admin_idint(11)发布公告的管理员的id
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_violation表

列名数据类型以及长度备注
violation_idint(11)主键 非空 自增 违章表记录的唯一标识
card_numberint(11)借阅证编号 固定 11位随机生成 非空
book_numberint(11)图书编号 非空 图书的唯一标识
borrow_datedatetime借阅日期 Java注解 JsonFormatter
close_datedatetime截止日期 Java注解 JsonFormatter
return_datedatetime归还日期 Java注解 JsonFormatter
violation_messagevarchar(100)违章信息 非空
violation_admin_idint(11)违章信息管理员的id
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_comment表

列名数据类型以及长度备注
comment_idint(11)主键 非空 自增 留言表记录的唯一标识
comment_avatarvarchar(255)留言的头像
comment_barrage_stylevarchar(32)弹幕的高度
comment_messagevarchar(255)留言的内容
comment_timeint(11)留言的时间(控制速度)
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_book_rule表

列名数据类型以及长度备注
rule_idint(11)主键 非空 自增 借阅规则记录的唯一标识
book_rule_idint(11)借阅规则编号 非空
book_daysint(11)借阅天数 非空
book_limit_numberint(11)限制借阅的本数 非空
book_limit_libraryvarchar(255)限制的图书馆 非空
book_overdue_feedouble图书借阅逾期后每天费用 非空
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

t_book_type表

列名数据类型以及长度备注
type_idint(11)主键 非空 自增 图书类别记录的唯一标识
type_namevarchar(32)借阅类别的昵称 非空
type_contentvarchar(255)借阅类别的描述 非空
create_timedatetime创建时间 Java注解 JsonFormatter
update_timedatetime更新时间 Java注解 JsonFormatter

🐼功能演示图

用户模块功能图

首页轮播图演示

image-20231030110318881

图书查询演示

image-20231030110329273

读者规则演示

image-20231030110333842

查看公告演示

image-20231030110340781

个人信息演示

image-20231030110345751

借阅信息演示

image-20231030110405947

违章信息演示

image-20231030110414231

读者留言演示

image-20231030110420564

智能推荐演示

image-20231030110529142

图书管理员功能图

借阅图书演示

image-20231030110551512

归还图书演示

image-20231030110611331

借书报表演示

image-20231030110618748

还书报表演示

image-20231030110626015

发布公告演示

image-20231030110634352

系统管理员功能图

  • 由于篇幅受限,系统功能展示主要功能。

系统管理演示

image-20231030110641741

image-20231030110649230

智能分析演示

image-20231030110656108

🐼部署项目

image-20231030110703088

  • 可以下载ZIP压缩包或者使用克隆(Git clone)
  • 复制http或者ssh的链接(github建议ssh,gittee都可以)
  • 在D盘新建一个文件夹,点击进入该文件夹,右键Git Bash Here

image-20231030110713924

  • 还没有下载Git或者不会Git的建议先看基础教程(30分钟左右)

  • 输入git init 初始化git项目 然后出现一个.git文件夹

  • 输入git remote add origin xxxxxx(xxx为刚刚复制的http或者ssh链接)

  • 输入git pull origin master 从远程代码托管仓库拉取代码

  • 成功拉取项目(前端后端都是如此)

  • 前端项目注意依赖下载使用npm install 或者 yarn install (Vscode或者Webstorm)

  • 后端项目注意maven依赖下载(IDEA(推荐)或者Ecplise)

  • 前端npm 镜像源建议淘宝镜像源,后端maven镜像源推荐阿里云镜像源(非必选,但更换后下载快速)

🐼部署项目问题

  • 乱码问题 项目采用的UFT-8
  • 一般出现乱码就是UTF-8和GBK二者相反
  • 请百度IDEA乱码和Eclipse乱码问题(描述清楚即可)

  • 点击交互按钮,没有发生反应。
  • 很明显,请求失败,浏览器打开开发者工具,Edge浏览器直接ctrl+shift+i,其他浏览器按F12
  • 查看红色的请求和响应状态码问题

  • 先阅读文档再进行问题的查询或者提问
  • 提问有技巧,模糊的发言,让高级架构师找BUG也无从下手

  • QQ:909088445
  • 一般晚上在线,建议先自己寻找问题!!!
  • 开源免费, 定制化和调试项目付费。

🐼项目API接口文档

  • 接口文档篇幅过大
  • 本来想完全采用RESTFUL风格,做到一半忘记了
  • 看清楚文档的基准地址
  • 要API后端接口文档详细内容和数据库结构+内容一起的,将前后端star⭐的截图加我QQ:909088445发我即可领取~感谢支持
数据库领取截图示例:

🐷其他

  • 个人博客地址: https://luoye6.github.io/
  • 个人博客采用Hexo+Github托管
  • 采用butterfly主题可以实现定制化
  • 推荐有空闲时间的,可以花1-2天搭建个人博客用于记录笔记。

智能图书馆开源项目icon-default.png?t=N7T8https://gitee.com/falle22222n-leaves/vue_-book-manage-system

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1464966.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

1+X电子商务运营数据采集(一)

王某在淘宝网经营着一个水果销售店铺,经过一年多的运营和推广,店铺生意毫无起色,而推广费用却没有少花。为此,王某准备对店铺的客户数据进行分析。采集了网店从开业到目前店铺的已有客户数据与行业客户人群画像进行比对&#xff0…

软件开发公司如何打造产品力,产品就是最好的推销员!

hello,我是贝格前端工场,作为开发公司,大家长期奉行的是SLG(销售驱动增长),一切围绕拿项目进行,那么是否可以采用PLG(产品驱动增长)呢?着力打造产品力&#x…

【前端素材】推荐优质后台管理系统Minia平台模板(附源码)

一、需求分析 后台管理系统是一种用于管理网站、应用程序或系统的工具,它通常作为一个独立的后台界面存在,供管理员或特定用户使用。下面详细分析后台管理系统的定义和功能: 1. 定义 后台管理系统是一个用于管理和控制网站、应用程序或系统…

数据结构与算法——排序算法

目录 文章目录 前言 一.排序的基本概念 1.什么是就地排序 2.什么是内部排序和外部排序 3.什么是稳定排序 4.判定一个排序算法的是稳定的 二.插入排序算法 1.直接插入排序 1.1基本思想 1.2复杂度 1.3稳定性 1.4代码演示 2.折半插入排序 2.1基本思想 2.2性能 3.…

如何进行非线性负载测试?

非线性负载测试是模拟真实用户行为和系统性能的测试方法,它可以帮助我们发现系统在高并发、高负载情况下的性能瓶颈和潜在问题。以下是进行非线性负载测试的一些建议: 在进行非线性负载测试之前,首先要明确测试的目标,例如测试系统…

Linux理解

VMware安装Linux安装 目录 VMware安装Linux安装 1.1 什么是Linux 1.2 为什么要学Linux 1.3 学完Linux能干什么 2.1 主流操作系统 2.2 Linux系统版本 VMware安装Linux安装 1.1 什么是Linux Linux是一套免费使用和自由传播的操作系统。 1.2 为什么要学Linux 1). 企业用人…

flutter开发实战-StreamBuilder使用介绍及实例

flutter开发实战-StreamBuilder使用介绍及实例 StreamBuilder是一个Widget,它依赖Stream来做异步数据获取刷新widget。 一、Stream Stream是一种用于异步处理数据流的机制,它允许我们从一段发射一个事件,从另外一段去监听事件的变化.Strea…

成功经营社区店的商业模式与案例分析

随着互联网的发展,线上购物已经成为了人们生活中不可或缺的一部分。然而,实体店依然具有不可替代的优势,特别是在社区环境中。 社区店不仅能够为居民提供便利的购物体验,还能为店主带来稳定的收入。 本人在社区开鲜奶吧已经5年时…

每日一题——LeetCode1502.判断是否能形成等差数列

方法一 排序 var canMakeArithmeticProgression function(arr) {arr.sort((a,b)>a-b)let diff arr[1]-arr[0]for(let i1;i<arr.length;i){if(arr[i]-arr[i-1]diff) continueelse return false}return true }; 消耗时间和内存情况&#xff1a; 方法二 数学方法 找出ar…

【算法与数据结构】417、LeetCode太平洋大西洋水流问题

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;题目要求雨水既能流向太平洋也能流向大西洋的网格。雨水流向取决于网格的高度。一个比较直接的方式是对…

web.py架构使用database接口连接mysql

安装mysql sudo apt-get update sudo apt-get install mysql-server sudo apt-get install mysql-client测试mysql systemctl status mysql.service配置mysql //修改密码 sudo mysql -u root -p set password for 用户名localhost password(新密码); //修改root的host属性…

【C语言基础教程】getline函数与临时文件

文章目录 前言一、getline函数1.1 为什么需要这个函数1.2 getline函数的使用1.3 使用示例 二、临时文件2.1 临时文件的使用2.2 示例代码 总结 前言 在C语言编程中&#xff0c;处理文本文件是一个常见的任务。然而&#xff0c;有时候我们需要处理那些我们不想在磁盘上创建的临时…

【Flink集群RPC通讯机制(四)】集群组件(tm、jm与rm)之间的RPC通信

文章目录 1. 集群内部通讯方法概述2. TaskManager向ResourceManager注册RPC服务3. JobMaster向ResourceManager申请Slot计算资源 现在我们已经知道Flink中RPC通信框架的底层设计与实现&#xff0c;接下来通过具体的实例了解集群运行时中组件如何基于RPC通信框架构建相互之间的调…

Windows10和Ubuntu22.04双系统安装

概要&#xff1a; 本篇演示Windows10和Ubuntu22.04双系统的安装&#xff0c;先安装Windows10&#xff0c;再安装Ubuntu22.04。 先安装Ubuntu22.04&#xff0c;后安装Windows10见&#xff1a; Ubuntu22.04和Windows10双系统安装-CSDN博客 一、说明 1、电脑 笔者的电脑品牌…

备战蓝桥杯—— 双指针技巧巧答链表2

对于单链表相关的问题&#xff0c;双指针技巧是一种非常广泛且有效的解决方法。以下是一些常见问题以及使用双指针技巧解决&#xff1a; 合并两个有序链表&#xff1a; 使用两个指针分别指向两个链表的头部&#xff0c;逐一比较节点的值&#xff0c;将较小的节点链接到结果链表…

解决Maven爆红以及解决 Idea 卡在 Resolving问题

关于 Idea 卡在 Resolving&#xff08;前提是Maven的setting.xml中配置好了阿里云和仓库&#xff09; 参考文章https://blog.csdn.net/jiangyu1013/article/details/95042611 解决Maven爆红参考文章https://devpress.csdn.net/beijing/656d993b76f0791b6eca7bb0.html?dp_toke…

使用k-近邻算法改进约会网站的配对效果(kNN)

目录 谷歌笔记本&#xff08;可选&#xff09; 准备数据&#xff1a;从文本文件中解析数据 编写算法&#xff1a;编写kNN算法 分析数据&#xff1a;使用Matplotlib创建散点图 准备数据&#xff1a;归一化数值 测试算法&#xff1a;作为完整程序验证分类器 使用算法&…

跨城租赁再复用 | 保利经典款展厅珠江之畔云游湘江之滨盛大启幕

2023年5月1日 由优积出品的 长沙保利-梅溪天珺营销中心 唯美亮相&#xff0c;举城共鉴&#xff0c;不负一城期待 盛大开放&#xff01; 优积科技可拆装售楼部 首次服务湖南项目 保利梅溪天珺与君说 &#xff0c;赞51 ▲点击观看展厅开放盛况 长沙保利梅溪天珺售楼处是从佛山…

硬件驱动为什么要有WHQL数字签名?

为了保证驱动程序的安全性&#xff0c;避免用户下载到不利于系统稳定和安全的驱动程序&#xff0c;驱动程序签名被设立出来。最初这一过程由代码签名证书来完成&#xff0c;现在取而代之的则是需要对驱动程序做WHQL认证。本文将详细介绍硬件驱动为什么要有WHQL数字签名的相关内…

如何用GPT高效地处理文本、文献查阅、PPT编辑、编程、绘图和论文写作?

原文链接&#xff1a;如何用GPT高效地处理文本、文献查阅、PPT编辑、编程、绘图和论文写作?https://mp.weixin.qq.com/s?__bizMzUzNTczMDMxMg&mid2247594986&idx4&sn970f9ba75998f2dd9fa5707d1611a6cc&chksmfa82320dcdf5bb1bdf58c20686d4eb209770e68253ed90d…