# librarySystem **Repository Path**: lms2000/librarySystem ## Basic Information - **Project Name**: librarySystem - **Description**: 图书管理系统(只有接口) - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 1 - **Forks**: 0 - **Created**: 2021-02-18 - **Last Updated**: 2024-12-16 ## Categories & Tags **Categories**: Uncategorized **Tags**: Redis, SpringBoot ## README # 图书管理系统 ## 项目介绍 前台页面(即本书图书管理系统的首页)实现了公告的显示,图书查询,留言建议三大主要功能,有读者规则查看功能,师生们可以看到图书管理人员发布的最新公告信息,并可以查询自己感兴趣的图书,查看留言提议,用户登录后还有个人资料修改、个人借阅信息查询、个人违章信息查询等功能,也可以给学校的图书管理人员留言提议。 后台的页面则集成了图书管理中所需的功能,分成图书管理人员和系统管理人员,平时管理人员的工作都是在后台中完成的。前台是为了师生显示的。相对应的后台是针对学校图书管理人员,后台的页面都加密,如果不正常登录是进入不了后台管理页面的,后台图书管理人员功能包括:借阅图书、归还图书、借书记录显示与查找、还书记录显示与查找、公告增删改查;后台系统管理员功能包括:对书籍的增删改查、对书籍分类的增删改、对借阅证的增删改查、对借阅信息的显示与查找、对借阅规则的增删改、对图书管理员的增删改、对近期借阅书籍数量的折线图显示,以及对这些表格数据进行Excel表格的输出 ### 使用到的技术栈 #### 前端:vue.js , element_ui , node.js ,jq #### 后端:spring boot ,spring security #### 数据库:mysql8.11 , 数据源(druid) #### 中间件:redis , spring eureka #### 工具库:mail,jjwt, jackson #### 服务器:centos 7 ### 一、用户模块 1. 查看公告:能看到图书管理员发布的公告信息。 2. 图书查看:分页显示,能看到图书总览,能通过图书编号、图书名称、作者、存放位置、图书描述进行模糊查询 3. 个人违章信息(登录后):个人历史违章信息与查询 4. 图书馆读者留言(登录后):对图书馆的建议,或对书籍的评价 5. 查看借阅规则:不同的规则有不同的借阅限定数量、限定时间、超期费用 6. 个人信息(登录后):对个人信息的查看与登录密码的修改 7. 个人借阅信息(登录后):对个人借阅记录的分页查看与查询 ### 二、图书管理员模块 1. 借还图书:帮助用户借阅图书,并判断符不符合借阅规则、返还图书时判断有没有超期,超期则输出超期费用再归还 2. 借阅报表:分页显示所有借阅记录、能进行查询和输出结果到excel公告管理:能添加编辑和删除公告 3. 还书报表:分页显示所有未还的书籍,能通过借阅证号、图书编号、借阅日期、截止日期等条件进行模糊查询 4. 个人信息修改:修改个人信息、密码等 ### 三、系统管理员 1. 书籍管理:分页,新添图书,设置图书各种信息,编辑删除,通过编号、书名、作者、描述等进行搜索,输出结果到excel,并且能查看该书籍被谁借阅过。 2. 分类管理:分页显示,增删改书籍分类,书籍分类方便查阅整理 3. 借阅证管理:分页显示所有借阅证,增删改查用户借阅证,查看该借阅证所有的借阅记录 4. 借阅规则管理:能显示、编辑、删除所有借阅规则,借阅规则将决定该图书证能借阅什么图书馆的图书,能借多少本,能借多久以及超期每天的费用。 5. 借阅信息查询:分页显示,能条件查询超期没还的,根据编号、借阅证号、书籍编号、借阅日期等进行模糊查询,输出结果到excel等,系统管理员只能查询,不能增删改借阅信息,这个操作由图书管理员操作。 6. 图书管理员管理:对图书管理员进行增删改操作,但是不能修改原来的账号 7. 图书借阅统计:通过折线图将图书馆近30天的每天借阅书籍数量直观的显示出来。 ## 项目设计 ### sql表设计 共有十张数据库表,书籍表、借书记录表、留言表、系统管理员表、借阅证表、图书管理管理员表书籍分类表、图书馆表、借阅规则表、公告表 - 书籍表 | 编号 | b_id | bigint(11) | 主键 | | -------- | ------------- | ------------ | ---- | | 书名 | book_name | varchar(32) | | | 作者 | book_author | varchar(16) | | | 图书编号 | library_id | bigint(11) | 外键 | | 分类编号 | sort_id | bigint(11) | 外键 | | 存放位置 | book_position | varchar(64) | | | 是否借出 | book_status | smallint(2) | | | 书籍描述 | description | varchar(255) | | - 编号、姓名、作者、存放的图书馆(外键:图书馆表的编号)、分类编号(外键:书籍分类表的编号)、存放位置、是否借出、书籍描述 - 借书记录表 | 编号 | bb_id | bigint(11) | 主键 | | ---------- | ----------- | ------------ | --------------------- | | 借阅证编号 | card_id | bigint(11) | 外键 | | 书籍编号 | book_id | bigint(11) | 外键 | | 借书日期 | borrow_date | datetime | | | 限制日期 | end_date | datetime | | | 归还日期 | return_date | datetime | | | 违规描述 | illegal | varchar(255) | | | 处理人编号 | manager_id | varchar(20) | 外键admin表的username | - 编号、借阅证编号(借阅证表的编号)、书籍编号(外键:书籍表的编号)、借书日期、限制日期、归还日期、违规描述、处理人编号(外键:图书管理员编号) - 留言表 - | 编号 | message_id | bigint(11) | 主键 | | ---------- | ----------- | ------------ | ---- | | 借阅证编号 | card_id | bigint(11) | 外键 | | 留言内容 | detail | varchar(255) | | | 留言日期 | public_date | datetime | | - 编号、借阅证编号(借阅证表的编号)、留言内容、留言日期 - 系统管理员表 | 用户名 | user_name | varchar(20) | 主键 | | ------ | --------- | ----------- | ---- | | 密码 | password | varchar(20) | | - 账号、密码 - 借阅证表 | 编号(账号) | bc_id | bigint(11) | 主键 | | ---------- | ------------- | ----------- | ---- | | 密码 | password | varchar(20) | | | 借阅证姓名 | reader | varchar(20) | | | 规则编号 | rule_id | bigint(11) | 外键 | | 状态 | borrow_status | smallint(2) | 0,1 | - 编号、密码、借阅者姓名、规则编号(规则表的编号)、状态(丢失0、可用1) - 图书管理员表 | 编号 | m_id | bigint(11) | 主键 | | ---- | --------------- | ----------- | ---- | | 姓名 | manager_name | varchar(20) | | | 账号 | manager_account | varchar(20) | | | 密码 | password | varchar(20) | | | 邮箱 | email | varchar(20) | | - 编号、姓名、账号、密码、邮箱 - 书籍分类表 | 编号 | bs_id | bigint(11) | 主键 | | -------- | ----------- | ------------ | ---- | | 分类名 | bs_name | varchar(20) | | | 分类描述 | description | varchar(255) | | - 编号、分类名、分类描述 - 图书馆表 | 编号 | l_id | bigint(11) | 主键 | | -------- | ------------ | ------------ | ---- | | 图书馆名 | library_name | varchar(20) | | | 描述 | description | varchar(255) | | - 编号、图书馆名、描述 - 规则表 | 编号 | r_id | bigint(11) | | | ---------------- | -------------- | ------------- | ---- | | 限制借阅数量 | borrow_num | bigint(11) | | | 限制借阅天数 | limit_day | bigint(11) | | | 租界的图书馆 | borrow_library | varchar(20) | | | 图书超期每天费用 | overtime_fee | decimal(10,3) | | - 编号、限制借阅数量、限制借阅天数、图书超期每天费用 - 公告表 | 编号 | a_id | bigint(11) | 主键 | | -------- | ------------ | ------------ | ---- | | 标题 | title | varchar(20) | | | 公告内容 | detail | varchar(255) | | | 发布日期 | publish_date | datetime | | - 编号、标题、公告内容、发布日期 ### 接口设计 登陆服务 1. /admin/* 1) /admin/账号/密码 post 登陆 2) /admin/旧密码/新密码 put 修改密码 3) /admin delete 删除用户 4) /admin get 查看图书管理员列表 2. /user/* 1) /user/账号/密码 post 登陆 2)/user/账号/密码 put 修改密码 3) /user put 修改个人信息 3. /guest/* 1)/guest/账号/密码 post 登陆 2) /guest get 获取guest 列表 3)/guest/id delete 删除 指定guest 4) /guest post 添加guest 5) /guest put 修改guest 图书服务 1. /books/* 1) /books get 获取图书列表 2) /books post 添加图书 3) /books put 修改图书 4) /books delete 删除图书 借阅服务 1. /borrow/* 1) /borrow/return get 已归还的列表 2) /brrow/proceed get 还未归还的列表 公告服务 1. /announcement/* 1) /announcement get 获取全部公告 2) /announcement post 写入一条公告 3) /announcement put 修改 公告 4) /announcement delete 删除公告 规则管理 1. /rules/* 1) /rules get 获取全部规则 2) /rules post 添加 3) /rules put 修改 4) /rules delete 删除 分类管理 1. /sorts/* 1) /sorts get 2) /sorts post 3) /sorts put 4) /sorts delete