JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现

这篇具有很好参考价值的文章主要介绍了JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

课程设计总结

1    概述

1.1  项目开发背景

随着信息技术的快速发展,数字化管理已经成为各行各业提高效率和管理水平的重要手段。在图书管理领域,数字化管理系统可以有效地提高管理效率,提供更好的用户体验。本项目旨在开发一个基于Spring Boot的图书数字化管理系统,为管理员和读者提供便捷的操作和管理功能。

  • 自动化管理需求:传统的图书管理往往涉及大量的人工操作,包括手动记录借还信息、图书分类整理和查询等。通过开发一个数字化管理系统,可以实现自动化的图书管理,减少人力成本和提高工作效率。
  • 提升用户体验:对于图书馆或图书管理机构而言,提供一个方便易用的系统可以提升用户的体验和满意度。数字化管理系统可以提供在线图书查询、预约借阅、自助借还等功能,方便用户快速获取所需图书,并且减少繁琐的手续。
  • 数据统计和分析:数字化管理系统可以收集和存储大量的图书相关数据,包括借还记录、读者偏好、图书馆资源利用情况等。通过对这些数据进行统计和分析,可以为图书馆管理者提供决策支持,例如优化图书采购、调整借阅规则、推荐相关图书等。
  • 安全和保护:数字化管理系统可以加强对图书和图书借阅信息的安全管理。通过权限控制和身份验证,确保只有授权人员可以进行借阅操作,并保护读者隐私和借阅记录的安全。

通过这个基于Spring Boot的图书数字化管理系统,管理员和读者可以在线完成相关操作和管理流程,提高了管理效率,提供了更好的用户体验。同时,系统还具备安全性高、易于扩展和维护等特点,为图书管理提供了新的解决方案。

1.2  开发工具

本项目采用Windows 10IntelliJ IDEA进行系统开发。

1.3  采用的技术

本项目主要采用的技术有JavaMySQLMavenSpringBootMybatis-PlusMySQLVue3ElementPlus等。

l JavaJava是一种广泛使用的编程语言,它适用于各种领域,包括桌面应用程序、移动应用程序、网络应用程序等。

l MySQLMySQL是一种流行的开源关系数据库管理系统,它使用SQL语言作为查询语言,它被广泛应用于各种应用程序中,如JavaPython等。

l MavenMaven是一个用于管理Java项目的工具,它可以帮助构建、打包和部署Java应用程序,它还可以管理项目的依赖关系。

l SpringBootSpringBoot是一个用于快速构建基于Spring框架的Java应用程序的工具,它通过自动配置和快速开发接口简化了Java开发。

l Mybatis-PlusMybatis-Plus是一个增强Mybatis的插件,它提供了更简单的API和更强大的功能,如全表操作、分页查询等,可以更方便地使用Mybatis进行数据库操作。

l Vue3Vue3Vue.js框架的最新版本,它提供了一个强大的API,用于构建可复用的组件,并使用虚拟DOM来实现快速、高效的渲染。

l ElementPlusElementPlusElement UI的升级版,它提供了更多主题和组件,可以快速构建美观的Web应用程序界面。

1.4  项目成员

项目成员如表 1‑1 项目成员表 1‑1所示。

1‑1 项目成员

姓名

职位

负责范围

项目经理

负责设计系统架构,并整合资料

系统分析师

负责对系统的可行性进行分析,并编写实现与测试的内容

设计师

负责对前端页面的设计,并编写界面设计和数据库设计的内容

前端开发

负责前端开发,并编写概述以及开发日志

后端开发

负责后端开发,并编写接口设计

测试工程师

负责测试系统,并编写实验总结

运维工程师

负责运维系统,并编写系统分析的内容

2    系统分析

2.1  需求分析

基于Spring Boot框架的数字化图书管理系统的需求分析包括账号管理、图书管理、借阅关系管理和操作台统计信息显示等功能模块。系统需要提供普通用户界面和管理员界面,普通用户和管理员都能借阅图书,管理员能够管理用户账号。此外,系统应具备统计功能,能够实时显示网站访问次数、用户数量、借阅数量和图书总量等统计信息。通过SSM框架的技术实现,系统能够实现用户注册、登录、图书录入、借阅操作和管理功能,满足用户的数字化图书管理需求。

2.1.1       成本考虑

在开发数字化图书管理系统的需求分析中,成本考虑是一个重要因素。团队规模为七人、时间限制为一周,资金不计。成本考虑包括人力成本、开发工具和环境成本、项目管理成本、硬件和基础设施成本,以及培训和支持成本。在评估成本时,需要综合考虑团队投入工时、技能水平、开发工具和基础设施需求,确保在给定时间内能够实现核心功能,并根据实际情况进行权衡和决策。

2.1.2       技术考虑

在技术考虑中,前端采用Vue框架,后端使用Spring Boot框架,数据库选择MySQL。技术考虑包括前端开发、后端开发、数据库选择、数据交互与API设计以及安全性考虑。通过合理利用这些技术,能够实现用户界面的交互和数据展示,实现业务逻辑和数据访问,确保数据的安全性和有效性,以满足系统的功能、性能和安全性要求。

2.1.3       市场考虑

市场考虑在需求分析中是至关重要的,包括明确目标用户群体、竞争分析、了解市场需求和趋势、设计合适的商业模式,并关注用户反馈和持续改进。通过这些市场考虑,系统能够满足目标用户的需求,与竞争对手保持竞争力,并在商业上具备可行性和市场适应性,以实现系统的成功和可持续发展。

2.1.4       用户考虑

用户考虑中,需要深入了解目标用户的特征和需求,设计用户友好的界面和良好的用户体验,鼓励用户参与和反馈,提供适当的培训和支持,以及确保用户隐私和数据安全。通过这些用户考虑,系统能够满足用户的期望和需求,提供优质的用户体验,并建立用户的信任和满意度,以实现系统的成功和用户的长期使用。

2.2  可行性分析

2.2.1       经济可行性

可行性分析主要关注开发成本和维护成本。根据团队规模为七人、时间限制为一周的条件,需对人力成本进行评估,确保在限定时间内完成核心功能开发。基于Spring Boot等开源框架的使用,可以减少开发成本,并且降低后续维护和升级的成本。进一步的经济可行性分析需要综合考虑系统的商业模式、收费方式和潜在收入,以确保系统能够获得足够的回报和盈利。

2.2.2       技术可行性

前端使用Vue框架,后端采用Spring Boot框架,数据库选择MySQL,这些技术都是成熟且广泛应用的技术栈,具备稳定性和可靠性。开发团队熟悉这些技术,并且有相关经验和技能,能够有效地开发和维护系统。相关的开发工具、集成环境和数据库管理工具等也易于获得和配置,支持系统的开发和部署。

2.2.3       操作可行性

系统的操作可行性指用户使用系统的便利性和可操作性。通过使用Vue框架和用户友好的界面设计,能够提供直观易用的用户界面,使用户能够方便地浏览图书、借阅和管理账号等。合理的界面交互和功能设计,以及提供适当的用户培训和支持,可以帮助用户快速上手并高效地使用系统。

2.3  功能分析

功能分析包括:账号管理,图书管理和借阅管理,此外还有查看用户数量,借阅数量,访问数量的显示台功能。账号管理分为普通用户账户管理和管理员账户管理;而管理员账号可以管理普通用户。图书管理包括添加图书,删除图书,查询图书和查询图书页面。在查询中,还包括单独查询和批量查询。借阅管理包括普通用户图书借阅和管理员图书借阅。用户借阅图书后,可以进行归还或者续借,管理员可以进行节约编辑,调整时间。

3    系统设计

3.1  功能概述

本系统分为管理员和读者模块。

管理员模块:注册、登录、书籍管理、读者管理、借阅管理、借阅状态、修改个人信息、修改密码

读者模块:注册、登录、查询图书信息、借阅和归还图书、查看个人借阅记录、修改个人信息、修改密码

系统结构图如图 3‑1所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑1 系统结构图

3.2  界面设计

3.2.1       注册页面

注册页面包括用户名、密码、确认密码、管理员/读者选项、验证码和注册按钮。用户完成这些步骤后即可成功注册,系统也将保存用户信息,提供后续操作的便利。具体页面如所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑2 读者注册页面

在选择管理员选项时,会多出一个管理员注册码,进行再一次的验证,以确保安全。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑3 管理员注册页面

3.2.2       登录页面

直接输入账号密码和验证码,如数据表中未找到该用户为此用户注册;如找到该用户,判断密码是否正确,正确即能进入用户个人页面。登录页面如图 3‑4所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑4 登录页面

3.2.3       用户展示板页面

用户展示页面包括已借阅数量,总访问的次数,图书的数量,用户数量以及统计图的展示,使得用更加直观的看到图书管理的情况。用户展示页面如图 3‑5所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑5 用户展示页面

3.2.4       用户个人信息

1)修改个人信息

修改个人信息可以变更用户名,姓名,电话号码,性别,地址最后进行保存。修改个人信息页面如图 3‑6所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑6 修改个人信息

2)修改密码

用户需要达到密码的安全性可以进行密码的修改,最后进行提交新密码。修改密码页面如图 3‑7所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑7 修改密码页面

3.2.5       用户图书查询

用户可以进行图书的查询,可以利用图书编号,图书名称以及作者进行查询。每次借阅最多5本书。用户图书查询页面如图 3‑8所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑8 用户图书查询

1)图书编号查询页面如图 3‑9所示。

 JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑9 图书编号查询

2)作者查询如图 3‑10所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑10 作者查询

3.2.6       用户借阅信息

用户可以进行查看图书是否归还,可以利用图书编号,图书名称以及作者进行查询归还状态。用户借阅信息页面如图 3‑11所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑11 用户借阅信息图

1)图书编号查询归还状态页面如图 3‑12所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑12 图书编号查询归还状态图

3.2.7       用户借阅信息

用户可以看自己借书的状态,在归还日期到了的时候,可以考虑是否续借。用户借阅信息如图 3‑13所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑13 用户借阅信息

3.2.8       管理员展示板

管理员展示页面包括已借阅数量,总访问的次数,图书的数量,用户数量以及统计图的展示,使得用更加直观的看到图书管理的情况。管理员展示板页面如图 3‑14所示

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑14 管理员展示板

3.2.9       管理员个人信息

1)修改个人信息

管理员可以修改个人信息可以变更用户名,姓名,电话号码,性别,地址最后进行保存。修改个人信息页面如图 3‑15所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑15 管理员个人信息图

2)修改密码

管理员需要达到密码的安全性可以进行密码的修改,最后进行提交新密码。修改密码页面如图 3‑16所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑16 修改密码

3.2.10     读者管理

管理员可以查看读者的信息,可以对读者的信息进行修改,也可以删除读者的信息。读者管理页面如图 3‑17所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑17 读者管理页面

3.2.11     书籍管理

管理员可以查看书籍的信息,可以对书籍的信息进行修改,也可以删除书籍的信息。书籍管理页面如图 3‑18所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java​​​​​​​

3‑18 书籍管理

3.2.12     借阅管理

管理员可以查看借阅信息,可以使用图书编号,图书名称,读者编号进行查阅。借阅管理页面如图 3‑19所示

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑19 借阅管理

图书编号查询如图 3‑20所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑20 图书编号查询

读者编号查询如图 3‑21所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑21 读者编号查询图

3.2.13     借阅状态

管理员可以查看书籍被那个读者借阅了,可以查看那本书被借了,可以修改借阅信息,也可以删除借阅信息。借阅状态页面如图 3‑22所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑22 借阅状态

3.3  接口设计

3.3.1       BookController

使用Spring Boot框架的RESTful接口控制器类,用于处理与图书相关的操作。以下BookController每个方法的功能解释,如 3‑1所示。

3‑1 BookController的方法

方法

作用

Result<?> save(@RequestBody Book Book)

保存一个Book对象到数据库,并返回保存后的结果。

Result<?> update(@RequestBody Book Book)

更新一个Book对象到数据库,并返回更新后的结果。

Result<?> deleteBatch(@RequestBody List<Integer> ids)

根据id删除一个Book对象,并返回删除后的结果。

Result<?> delete(@PathVariable Long id)

根据id删除一个Book对象,并返回删除后的结果。

3.3.2       BookWithUserController

使用Spring Boot框架的RESTful接口控制器类,用于处理与图书和用户相关的操作。以下是BookWithUserController的每个方法的功能解释,如 3‑2所示。

3‑2 BookWithUserController的方法

方法

作用

Result<?> insertNew(@RequestBody BookWithUser BookWithUser)

新增一个BookWithUser对象到数据库,并返回新增后的结果。

Result<?> update(@RequestBody BookWithUser BookWithUser)

更新一个BookWithUser对象到数据库,并返回更新后的结果。

Result<?> deleteRecord(@RequestBody BookWithUser BookWithUser)

删除一个BookWithUser对象到数据库,并返回删除后的结果。

3.3.3       DashboardController

使用Spring Boot框架的RESTful接口控制器类,用于处理与仪表板相关的操作。仪表板页面包括已借阅数量,总访问的次数,图书的数量,用户数量以及统计图的展示,使得用更加直观的看到图书管理的情况。

DashboardController类的主要作用是处理仪表盘页面的GET请求,并通过调用其他Mapper类的方法来获取相关统计信息,并将这些信息以键值对的形式存储在Map对象中,最终返回给调用者以展示仪表盘页面。

3.3.4       LendRecordController

使用Spring Boot框架的RESTful接口控制器类,用于处理与借阅记录相关的操作。以下是LendRecordController的每个方法的功能解释,如 3‑3所示。

3‑3 LendRecordController的方法

方法

作用

Result<?> deleteRecord(@RequestBody LendRecord LendRecord)

根据单个LendRecord对象进行删除操作,并返回删除后的结果。

Result<?> deleteRecords(@RequestBody List<LendRecord> LendRecords)

根据多个LendRecord对象进行批量删除操作,并返回删除后的结果。

Result<?> save(@RequestBody LendRecord LendRecord)

保存单个LendRecord对象到数据库,并返回保存后的结果。

3.3.5       UserController

使用Spring Boot框架的RESTful接口控制器类,用于处理与用户相关的操作。以下是UserController的每个方法的功能解释,如 3‑4所示。

3‑4 UserController的方法

方法

作用

Result<?> register(@RequestBody User user)

注册一个新用户到数据库,并返回注册后的结果。

Result<?> login(@RequestBody User user)

验证用户登录,并返回登录后的结果。

Result<?> save(@RequestBody User user)

保存用户信息到数据库,并返回保存后的结果。

Result<?> password(@RequestBody User user)

修改用户密码,并返回修改后的结果。

Result<?> deleteBatch(@RequestBody List<Integer> ids)

批量删除用户,并返回删除后的结果。

3.4  数据库设计

本系统的数据库一共有4张数据表,分别是bookbookwithuserlend_recorduser表,表设计,如图 3‑23到图 3‑26所示。

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑23 book表设计

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑24 bookwithuser表设计

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑25 lend_record表设计

JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现,Java Web,spring boot,后端,java

3‑26 user表设计

4    实现与测试

4.1  关键技术实现(关键问题或难点是如何实现的)

4.1.1       BookController

本模块用于保存图书实体,通过bookMapper id更新图书,通过Batch id批量删除,通过bookMapper id删除图书,查找页面。

package com.example.demo.controller;

@RestController
@RequestMapping("/book")
public class BookController {
    @Resource
    BookMapper BookMapper;

    @PostMapping
    public Result<?> save(@RequestBody Book Book) {
        BookMapper.insert(Book);
        return Result.success();
    }

    @PutMapping
    public Result<?> update(@RequestBody Book Book) {
        BookMapper.updateById(Book);
        return Result.success();
    }

    //    批量删除
    @PostMapping("/deleteBatch")
    public Result<?> deleteBatch(@RequestBody List<Integer> ids) {
        BookMapper.deleteBatchIds(ids);
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result<?> delete(@PathVariable Long id) {
        BookMapper.deleteById(id);
        return Result.success();
    }

    @GetMapping
    public Result<?> findPage(@RequestParam(defaultValue = "1") Integer pageNum,
                              @RequestParam(defaultValue = "10") Integer pageSize,
                              @RequestParam(defaultValue = "") String search1,
                              @RequestParam(defaultValue = "") String search2,
                              @RequestParam(defaultValue = "") String search3) {
        LambdaQueryWrapper<Book> wrappers = Wrappers.<Book>lambdaQuery();
        if (StringUtils.isNotBlank(search1)) {
            wrappers.like(Book::getIsbn, search1);
        }
        if (StringUtils.isNotBlank(search2)) {
            wrappers.like(Book::getName, search2);
        }
        if (StringUtils.isNotBlank(search3)) {
            wrappers.like(Book::getAuthor, search3);
        }
        Page<Book> BookPage = BookMapper.selectPage(new Page<>(pageNum, pageSize), wrappers);
        return Result.success(BookPage);
    }
}

​​​​​​​4.1.2       BookWithUserController

本模块用于,插入新的借阅关系实体,通过图书名称和借阅关系id更新借阅关系,通过图书名称和借阅关系id删除一条或多条借阅关系记录,查找页面。具体代码如下。

package com.example.demo.controller;

@RestController
@RequestMapping("/bookwithuser")
public class BookWithUserController {
    @Resource
    BookWithUserMapper BookWithUserMapper;

    @PostMapping("/insertNew")
    public Result<?> insertNew(@RequestBody BookWithUser BookWithUser) {
        BookWithUserMapper.insert(BookWithUser);
        return Result.success();
    }

    @PostMapping
    public Result<?> update(@RequestBody BookWithUser BookWithUser) {
        UpdateWrapper<BookWithUser> updateWrapper = new UpdateWrapper<>();
        updateWrapper.eq("isbn", BookWithUser.getIsbn()).eq("id", BookWithUser.getId());
        BookWithUserMapper.update(BookWithUser, updateWrapper);
        return Result.success();
    }

    //删除一条记录
    @PostMapping("/deleteRecord")
    public Result<?> deleteRecord(@RequestBody BookWithUser BookWithUser) {
        Map<String, Object> map = new HashMap<>();
        map.put("isbn", BookWithUser.getIsbn());
        map.put("id", BookWithUser.getId());
        BookWithUserMapper.deleteByMap(map);
        return Result.success();
    }

    @PostMapping("/deleteRecords")
    public Result<?> deleteRecords(@RequestBody List<BookWithUser> BookWithUsers) {
        int len = BookWithUsers.size();
        for (int i = 0; i < len; i++) {
            BookWithUser curRecord = BookWithUsers.get(i);
            Map<String, Object> map = new HashMap<>();
            map.put("isbn", curRecord.getIsbn());
            map.put("id", curRecord.getId());
            BookWithUserMapper.deleteByMap(map);
        }
        return Result.success();
    }

    @GetMapping
    public Result<?> findPage(@RequestParam(defaultValue = "1") Integer pageNum,
                              @RequestParam(defaultValue = "10") Integer pageSize,
                              @RequestParam(defaultValue = "") String search1,
                              @RequestParam(defaultValue = "") String search2,
                              @RequestParam(defaultValue = "") String search3) {
        LambdaQueryWrapper<BookWithUser> wrappers = Wrappers.<BookWithUser>lambdaQuery();
        if (StringUtils.isNotBlank(search1)) {
            wrappers.like(BookWithUser::getIsbn, search1);
        }
        if (StringUtils.isNotBlank(search2)) {
            wrappers.like(BookWithUser::getBookName, search2);
        }
        if (StringUtils.isNotBlank(search3)) {
            wrappers.like(BookWithUser::getId, search3);
        }
        Page<BookWithUser> BookPage = BookWithUserMapper.selectPage(new Page<>(pageNum, pageSize), wrappers);
        return Result.success(BookPage);
    }
 
}

4.1.3       DashboardController

本模块用于使用显示网站访问次数,用户数量,借阅记录,图书数量。具体代码如下。

package com.example.demo.controller;


@RestController
@RequestMapping("/dashboard")
public class DashboardController {
    @Resource
    private UserMapper userMapper;
    @Resource
    private LendRecordMapper lendRecordMapper;
    @Resource
    private BookMapper bookMapper;
    @GetMapping
    public  Result<?> dashboardrecords(){
        int visitCount = LoginUser.getVisitCount();
        QueryWrapper<User> queryWrapper1=new QueryWrapper();
        int userCount = userMapper.selectCount(queryWrapper1);
        QueryWrapper<LendRecord> queryWrapper2=new QueryWrapper();
        int lendRecordCount = lendRecordMapper.selectCount(queryWrapper2);
        QueryWrapper<Book> queryWrapper3=new QueryWrapper();
        int bookCount = bookMapper.selectCount(queryWrapper3);
        Map<String, Object> map = new HashMap<>();//键值对形式
        map.put("visitCount", visitCount);//放置visitCount到map中
        map.put("userCount", userCount);
        map.put("lendRecordCount", lendRecordCount);
        map.put("bookCount", bookCount);
        return Result.success(map);
    }
}

4.1.4       LendRecordController

本模块用于根据图书名称删除借阅记录,删除一条或多条借阅记录,保存借阅记录,查找页面,修改借阅记录。

package com.example.demo.controller;


@RestController
@RequestMapping("/LendRecord")
public class LendRecordController {
    @Resource
    LendRecordMapper LendRecordMapper;

    @DeleteMapping("/{isbn}")
    public Result<?> delete(@PathVariable String isbn) {
        Map<String, Object> map = new HashMap<>();
        map.put("isbn", isbn);
        LendRecordMapper.deleteByMap(map);
        return Result.success();
    }

    //删除一条记录
    @PostMapping("/deleteRecord")
    public Result<?> deleteRecord(@RequestBody LendRecord LendRecord) {
        Map<String, Object> map = new HashMap<>();
        map.put("isbn", LendRecord.getIsbn());
        map.put("borrownum", LendRecord.getBorrownum());
        LendRecordMapper.deleteByMap(map);
        return Result.success();
    }

    @PostMapping("/deleteRecords")
    public Result<?> deleteRecords(@RequestBody List<LendRecord> LendRecords) {
        int len = LendRecords.size();
        for (int i = 0; i < len; i++) {
            LendRecord curRecord = LendRecords.get(i);
            Map<String, Object> map = new HashMap<>();
            map.put("isbn", curRecord.getIsbn());
            map.put("borrownum", curRecord.getBorrownum());
            LendRecordMapper.deleteByMap(map);
        }
        return Result.success();
    }

    @PostMapping
    public Result<?> save(@RequestBody LendRecord LendRecord) {
        LendRecordMapper.insert(LendRecord);
        return Result.success();
    }

    @GetMapping
    public Result<?> findPage(@RequestParam(defaultValue = "1") Integer pageNum,
                              @RequestParam(defaultValue = "10") Integer pageSize,
                              @RequestParam(defaultValue = "") String search1,
                              @RequestParam(defaultValue = "") String search2,
                              @RequestParam(defaultValue = "") String search3) {
        LambdaQueryWrapper<LendRecord> wrappers = Wrappers.<LendRecord>lambdaQuery();
        if (StringUtils.isNotBlank(search1)) {
            wrappers.like(LendRecord::getIsbn, search1);
        }
        if (StringUtils.isNotBlank(search2)) {
            wrappers.like(LendRecord::getBookname, search2);
        }
        if (StringUtils.isNotBlank(search3)) {
            wrappers.like(LendRecord::getReaderId, search3);
        }
        Page<LendRecord> LendRecordPage = LendRecordMapper.selectPage(new Page<>(pageNum, pageSize), wrappers);
        return Result.success(LendRecordPage);
    }

    @PutMapping("/{isbn}")
    public Result<?> update(@PathVariable String isbn, @RequestBody LendRecord lendRecord) {
        UpdateWrapper<LendRecord> updateWrapper = new UpdateWrapper<>();
        updateWrapper.eq("isbn", isbn);
        LendRecord lendrecord = new LendRecord();
        lendrecord.setLendTime(lendRecord.getLendTime());
        lendrecord.setReturnTime(lendRecord.getReturnTime());
        lendrecord.setStatus(lendRecord.getStatus());
        LendRecordMapper.update(lendrecord, updateWrapper);
        return Result.success();
    }

    @PutMapping("/{lendTime}")
    public Result<?> update2(@PathVariable Date lendTime, @RequestBody LendRecord lendRecord) {
        UpdateWrapper<LendRecord> updateWrapper = new UpdateWrapper<>();
        updateWrapper.eq("lendTime", lendTime);
        LendRecord lendrecord = new LendRecord();
        lendrecord.setReturnTime(lendRecord.getReturnTime());
        lendrecord.setStatus(lendRecord.getStatus());
        LendRecordMapper.update(lendrecord, updateWrapper);
        return Result.success();
    }

}

​​​​​​​ 4.1.5       UserController

本模块用于用户注册,用户登录,插入用户信息,修改密码,用户ID修改密码,批量删除ID,通过昵称查找书籍页面。

具体实现代码如下:

package com.example.demo.controller;

@RestController
@RequestMapping("/user")
public class UserController {
    @Resource
    UserMapper userMapper;

    @PostMapping("/register")
    public Result<?> register(@RequestBody User user) {
        User res = userMapper.selectOne(Wrappers.<User>lambdaQuery().eq(User::getUsername, user.getUsername()));
        if (res != null) {
            return Result.error("-1", "用户名已重复");
        }
        userMapper.insert(user);
        return Result.success();
    }

    @CrossOrigin
    @PostMapping("/login")
    public Result<?> login(@RequestBody User user) {
        User res = userMapper.selectOne(Wrappers.<User>lambdaQuery().eq(User::getUsername, user.getUsername()).eq(User::getPassword, user.getPassword()));
        if (res == null) {
            return Result.error("-1", "用户名或密码错误");
        }
        String token = TokenUtils.genToken(res);
        res.setToken(token);
        LoginUser loginuser = new LoginUser();
        loginuser.addVisitCount();
        return Result.success(res);
    }

    @PostMapping
    public Result<?> save(@RequestBody User user) {
        if (user.getPassword() == null) {
            user.setPassword("abc123456");
        }
        userMapper.insert(user);
        return Result.success();
    }

    @PutMapping("/password")
    public Result<?> update(@RequestParam Integer id,
                            @RequestParam String password2) {
        UpdateWrapper<User> updateWrapper = new UpdateWrapper<>();
        updateWrapper.eq("id", id);
        User user = new User();
        user.setPassword(password2);
        userMapper.update(user, updateWrapper);
        return Result.success();
    }

    @PutMapping
    public Result<?> password(@RequestBody User user) {
        userMapper.updateById(user);
        return Result.success();
    }

    @PostMapping("/deleteBatch")
    public Result<?> deleteBatch(@RequestBody List<Integer> ids) {
        userMapper.deleteBatchIds(ids);
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result<?> delete(@PathVariable Long id) {
        userMapper.deleteById(id);
        return Result.success();
    }

    @GetMapping
    public Result<?> findPage(@RequestParam(defaultValue = "1") Integer pageNum,
                              @RequestParam(defaultValue = "10") Integer pageSize,
                              @RequestParam(defaultValue = "") String search) {
        LambdaQueryWrapper<User> wrappers = Wrappers.<User>lambdaQuery();
        if (StringUtils.isNotBlank(search)) {
            wrappers.like(User::getNickName, search);
        }
        wrappers.like(User::getRole, 2);
        Page<User> userPage = userMapper.selectPage(new Page<>(pageNum, pageSize), wrappers);
        return Result.success(userPage);
    }

    @GetMapping("/usersearch")
    public Result<?> findPage2(@RequestParam(defaultValue = "1") Integer pageNum,
                               @RequestParam(defaultValue = "10") Integer pageSize,
                               @RequestParam(defaultValue = "") String search1,
                               @RequestParam(defaultValue = "") String search2,
                               @RequestParam(defaultValue = "") String search3,
                               @RequestParam(defaultValue = "") String search4) {
        LambdaQueryWrapper<User> wrappers = Wrappers.<User>lambdaQuery();
        if (StringUtils.isNotBlank(search1)) {
            wrappers.like(User::getId, search1);
        }
        if (StringUtils.isNotBlank(search2)) {
            wrappers.like(User::getNickName, search2);
        }
        if (StringUtils.isNotBlank(search3)) {
            wrappers.like(User::getPhone, search3);
        }
        if (StringUtils.isNotBlank(search4)) {
            wrappers.like(User::getAddress, search4);
        }
        wrappers.like(User::getRole, 2);
        Page<User> userPage = userMapper.selectPage(new Page<>(pageNum, pageSize), wrappers);
        return Result.success(userPage);
    }
}

5    开发日志

本团队开发日志如下。

202373日:

l 使用IDEA开发工具创建Spring Boot项目,配置项目的基本信息和依赖。

l 配置数据库连接信息,包括MySQLURL、用户名和密码。

l 设计数据库表结构。

l 编写数据库初始化脚本,创建数据库表并插入初始数据。

202374日:

l 引入MyBatis-Plus依赖,配置MyBatis-Plus的相关信息。

l 创建图书管理、用户管理等模块的Service接口和实现类。

l 实现图书管理模块的增删改查功能,包括图书的添加、删除、修改和查询。

l 完成用户管理模块的相关功能,如用户的注册、登录、权限管理等。

202375日:

l 开发图书借阅管理模块,包括借阅记录的添加、查询和归还功能。

l 实现用户权限管理功能,根据用户角色限制不同操作的权限。

l 完善前端页面的布局和样式。

202376日:

l 添加搜索功能,根据关键字查询图书信息。

l 完善系统的异常处理和错误提示,提高系统的健壮性和用户体验。

l 进行系统的测试和调试,修复存在的Bug和问题。

202377日:

l 进行项目的总结和评估,总结开发过程中的经验和教训。

l 准备项目的演示文稿和演示材料,用于项目的答辩。

l 进行项目的答辩,展示系统的功能和设计思路,回答相关问题。

6    设计总结

在这次实训课中,我们小组设计并成功开发了一个图书数字化管理系统。这个系统的目标是提供一个高效、便捷的图书管理平台,使图书馆管理员能够轻松管理图书的借阅、归还和库存等操作。通过本次实训课的设计和实现,我们小组实现了图书的录入、借阅、归还和查询等功能,并且系统设计合理、功能完善,用户界面友好。同时,我们对数据库设计、编程技术和系统集成有了更深入的理解和实践。

在这次实训课的经历中,我们小组的成员有了一些共同的感悟和收获。

实践是学习的关键。实训课为我们提供了一个实践的机会,让我们能够将课堂上学到的理论知识应用到实际项目中。通过亲身实践,我们深刻理解了许多概念和原则,并学会了解决实际问题的方法。

团队合作的重要性。在实训课中,我们小组的成员一起组成团队,共同完成项目。团队合作是非常关键的,通过分工合作和协作交流,我们能够高效地完成任务。我们学到了如何与他人合作,倾听和尊重他人的意见,共同追求项目的成功。

面对挑战要有耐心和毅力。在实训过程中,我们遇到了各种各样的挑战,如技术难题、时间压力等。但是,我们学会了保持耐心和毅力,积极寻找解决方案,不断尝试和学习。这让我们明白到,在面对困难时,坚持不懈的努力是能够克服障碍并取得进步的关键。

要注重细节和质量。在实训课中,我们意识到细节的重要性。一个小小的错误或遗漏可能会导致系统的不稳定或功能缺失。因此,我们学会了注重细节,审慎检查代码和设计,以确保系统的质量和可靠性。

持续学习和自我提升。实训课只是学习的起点,我们意识到在不断发展的技术领域,学习是一个持续的过程。我们要时刻保持学习的心态,跟上最新的技术和趋势,不断提升自己的能力和知识水平。

规划和时间管理。在实训课开始之前我们制定了详细的项目计划和时间表这有助于我们合理分配任务和时间,避免了项目进度的拖延。我们学会了如何有效地规划和管理我们的时间,以便在限定的时间内完成任务。

沟通和协作能力。团队合作是实训课的关键要素。我们需要与团队成员密切合作共同制定方案讨论问题并解决挑战,通过与他人的沟通和协作,我们提高了我们的沟通能力和团队合作技巧。我们学会了倾听他人的观点尊重不同的意见并在团队中扮演积极的角色。

解决问题的能力。在实训过程中我们遇到了许多技术和设计上的问题,有时候我们需要独立解决问题,也有时候需要团队共同努力。我们学会了如何分析问题,寻找解决方案并采取适当的行动来解决问题,这让我们对问题解决的过程有了更深入的了解并增强了我们解决问题的能力。

学习与实践的结合。实训课提供了一个理论与实践相结合的学习环境,通过将所学的理论知识应用到实际项目中,我们深化了对课程内容的理解,并掌握了实际应用的技能这种学习方式,让我们在实践中不断成长,并将知识转化为实际能力。

自我反思和持续改进。在实训课的过程中,我们不断反思自己的表现和学习进展,我们意识到自己的优点和不足并积极采取措施改进自己。通过持续的自我反思和改进,我们能够不断提升自己的技能和能力。

通过这次实训课我们小组不仅获得了实际项目开发的经验,还培养了自我管理团队合作和问题解决的能力。这些宝贵的经验将对我们小组的成员未来的学习和职业发展产生长远的影响,我们期待将这些经验应用于未来的项目和挑战中,并不断成长和提升自己。

编码不易,有偿分享代码和原文档,有意私聊VX: liwoaa文章来源地址https://www.toymoban.com/news/detail-558645.html

到了这里,关于JavaWeb——基于Spring Boot的图书数字化管理系统的设计与实现的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 制造工厂ERP系统:从数字销售-生产到财务管理,掌握企业数字化十大核心!

    在快速发展的数字化时代,企业(尤其是传统生产制造行业)面临着诸多挑战与机遇。无论是客户体验、供应链管理还是内部流程优化,数字化都在发挥着关键作用。为了更好地应对数字化带来的挑战和机遇为了更好地应对市场变化和提高竞争力,实施数字化管理已成为企业

    2024年01月18日
    浏览(63)
  • 浅谈企业数字化转型之主数据管理系统(MDM)

    信息化的时代已经快要过去,传统的ERP系统只能满足企业节省劳力,将日常的业务流程以各种不同的IT信息系统的形式固定下来,并留下记录,提高企业管理效率。 越来越多的企业开始向数字化、数智化方向转型,主数据管理系统是转型过程中的基石,在后期能够为企业提供

    2024年02月05日
    浏览(56)
  • 基于Spring boot的图书商城管理系统-源码、数据库、LW

    框架:Springboot 数据库:MySQL 下载链接: https://download.csdn.net/download/yw1990128/87851197 B站运行链接: 基于Springboot的图书商城管理系统_哔哩哔哩_bilibili 引言 项目开发背景 Internet最早在美国出现,如今,世界各国纷纷加入到这个行列,便Internet成 为全球化的网际网络。随着用户的

    2024年02月07日
    浏览(55)
  • 数字化棋牌室 | 会员管理预约系统 | 棋牌室小程序

    棋牌室 在城市与农村都是部分老年人与年轻人的经常去的娱乐场所,以前这些场所里总是挤满了人,但现在越来越多的棋牌室即使环境装修的漂亮、设备高端完善等依然面对流量难题及管理难题,同时由于棋牌室具有社区属性,因此也有不少商家打出品牌多地开分店,打造娱

    2024年02月10日
    浏览(51)
  • 亿发数字化生产工厂MES管理系统,助力云南工厂实现智能制造

    近年来,云南省将制造业数字化作为“工业强省”战略的关键和打造现代产业体系的重中之重,而随着工业4.0时代的来临,数字化转型已成为制造企业企业蓬勃发展之路。在这个过程中,MES精益制造管理系统显露出潜力,成为云南省实现智能工厂的关键部分。 接下来,本文将

    2024年02月15日
    浏览(62)
  • 智慧园区SaaS管理系统解决方案:赋能园区实现信息化、数字化管理

    智慧园区的概念来源于智慧城市,是指应用云计算、互联网等新一代信息通信技术,改变园区中各机构的交互方式,提高交互效率的新型科技园区。近年来,我国智慧园区发展迅速,随着大数据、人工智能等技术的发展不断取得新突破,以科技赋能产业园区数字化升级是必然

    2024年02月02日
    浏览(63)
  • 企业工程项目管理系统源码-专注项目数字化管理-Java工程管理-二次开发

        工程项目各模块及其功能点清单 一、系统管理     1、数据字典:实现对数据字典标签的增删改查操作     2、编码管理:实现对系统编码的增删改查操作     3、用户管理:管理和查看用户角色     4、菜单管理:实现对系统菜单的增删改查操作     5、角色管理:管理

    2024年02月07日
    浏览(61)
  • java版工程项目管理系统平台,助力工程企业实现数字化管理系统源代码

            Java版工程项目管理系统 Spring Cloud+Spring Boot+Mybatis+Vue+ElementUI+前后端分离 功能清单如下: 首页 工作台:待办工作、消息通知、预警信息,点击可进入相应的列表 项目进度图表:选择(总体或单个)项目显示1、项目进度图表  2、项目信息 施工地图:1、展示当前角

    2024年02月08日
    浏览(66)
  • 数商云钢材行业智慧供应商管理系统:降低企业运营成本,构建数字化供应商管理体系

    钢材行业是国民经济的基础产业,其产业链长、规模大、涉及面广,对国家经济发展有着重要的影响。根据中国钢铁工业协会的数据显示,2020年我国钢材销售量达73996万吨,同比2019年增长12.6%。 图片来源:华经产业研究院 我国钢材行业产业链游参与主体为原材料供应商,提

    2024年02月01日
    浏览(55)
  • 企业电子招投标采购系统——功能模块&功能描述+数字化采购管理 采购招投标

    功能模块: 待办消息,招标公告,中标公告,信息发布   描述: 全过程数字化采购管理,打造从供应商管理到采购招投标、采购合同、采购执行的全过程数字化管理。通供应商门户具备内外协同的能力,为外部供应商集中推送展示与其相关的所有采购业务信息(历史合作、

    2024年02月04日
    浏览(49)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包