springboot149智慧图书管理系统设计与实现

博主介绍:专注于Java(springboot ssm 等开发框架) vue  .net  php phython node.js    uniapp 微信小程序 等诸多技术领域和毕业项目实战、企业信息化系统建设,从业十五余年开发设计教学工作
☆☆☆ 精彩专栏推荐订阅☆☆☆☆☆不然下次找不到哟
我的博客空间发布了2000+毕设题目 方便大家学习使用
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多的人
文末下方有源码获取地址

4.1 功能结构设计

图4.1即为设计的管理员功能结构,管理员权限操作的功能包括对注册读者信息的管理,对图书,对图书留言,对图书借阅记录,对论坛帖子等信息的管理。

图4.1 管理员功能结构

图4.2即为设计的读者功能结构,读者权限操作的功能包括借阅图书,对图书进行留言或收藏图书,查看论坛帖子信息,查看借阅的图书等。

图4.2 读者功能结构

4.2 数据库设计

4.2.1 数据库概念设计

  1. 图4.8即为上面介绍的实体中存在的联系。

图4.8 实体间关系E-R图

4.2.2 数据库物理设计

表4.1 读者表

字段

注释

类型

id (主键)

主键

int(11)

username

账户

varchar(200)

password

密码

varchar(200)

duzhe_uuid_number

读者编号

varchar(200)

duzhe_name

读者姓名

varchar(200)

duzhe_phone

读者手机号

varchar(200)

duzhe_id_number

读者身份证号

varchar(200)

duzhe_photo

读者头像

varchar(200)

sex_types

性别

int(11)

duzhe_types

读者类型

int(11)

duzhe_email

电子邮箱

varchar(200)

create_time

创建时间

timestamp

表4.2 论坛表

字段

注释

类型

id (主键)

主键

int(11)

forum_name

帖子标题

varchar(200)

duzhe_id

读者

int(11)

users_id

管理员

int(11)

forum_content

发布内容

text

super_ids

父id

int(11)

forum_types

帖子类型

int(11)

forum_state_types

帖子状态

int(11)

insert_time

发帖时间

timestamp

update_time

修改时间

timestamp

create_time

创建时间

timestamp

表4.3 图书表

字段

注释

类型

id (主键)

主键

int(11)

tushu_uuid_number

图书编号

varchar(200)

tushu_name

图书名称

varchar(200)

tushu_photo

图书照片

varchar(200)

shujia_types

书架

int(11)

tushu_types

图书类型

int(11)

tushu_zuozhe

图书作者

varchar(200)

tushu_chubanshe

出版社

varchar(200)

tushu_kucun_number

图书库存

int(11)

shangxia_types

是否上架

int(11)

tushu_delete

逻辑删除

int(11)

tushu_content

图书介绍

text

create_time

创建时间

timestamp

表4.4 图书收藏表

字段

注释

类型

id (主键)

主键

int(11)

tushu_id

图书

int(11)

duzhe_id

读者

int(11)

tushu_collection_types

类型

int(11)

insert_time

收藏时间

timestamp

create_time

创建时间

timestamp

表4.5 图书留言表

字段

注释

类型

id (主键)

主键

int(11)

tushu_id

图书

int(11)

duzhe_id

读者

int(11)

tushu_liuyan_text

留言内容

text

reply_text

回复内容

text

insert_time

留言时间

timestamp

update_time

回复时间

timestamp

create_time

创建时间

timestamp

表4.6 图书借阅表

字段

注释

类型

id (主键)

主键

int(11)

tushu_order_uuid_number

借阅编号

varchar(200)

tushu_id

图书

int(11)

duzhe_id

读者

int(11)

jieyue_time

借阅日期

date

huanshu_time

还书日期

date

tushu_order_types

状态

int(11)

insert_time

添加时间

timestamp

create_time

创建时间

timestamp

表4.7 管理员表

字段

注释

类型

id (主键)

主键

bigint(20)

username

用户名

varchar(100)

password

密码

varchar(100)

role

角色

varchar(100)

addtime

新增时间

timestamp


第5章 系统实现

编程人员在搭建的开发环境中,运用编程技术实现本系统设计的各个操作权限的功能。在本节中,就展示部分操作权限的功能与界面。

5.1 管理员功能实现

5.1.1 论坛管理

图5.1 即为编码实现的论坛管理界面,管理员在该界面中查看论坛回复信息,修改论坛帖子内容,可以删除论坛帖子。

图5.1 论坛管理界面

5.1.2 读者管理

图5.2 即为编码实现的读者管理界面,管理员在该界面中为注册系统的读者重置密码,更改读者的头像,电子邮箱等基础信息,删除需要删除的读者。

图5.2 读者管理界面

5.1.3 图书留言管理

图5.3 即为编码实现的图书留言管理界面,管理员在该界面中对读者提交的图书留言信息进行回复,可以查询,删除读者对图书的留言。

图5.3 图书留言管理界面

5.1.4 借阅记录管理

图5.4 即为编码实现的借阅记录管理界面,管理员在该界面中查看图书借阅记录排行榜,查看借阅图书的目前状态是否为已还书状态,查看借阅图书的详情信息。

图5.4 借阅记录管理界面

5.1.5 图书管理

图5.5 即为编码实现的图书管理界面,管理员在该界面中对图书库存进行管理,包括增加或减少库存,能够下架图书,新增图书等。

图5.5 图书管理界面


package com.controller;

import java.io.File;
import java.math.BigDecimal;
import java.net.URL;
import java.text.SimpleDateFormat;
import com.alibaba.fastjson.JSONObject;
import java.util.*;
import org.springframework.beans.BeanUtils;
import javax.servlet.http.HttpServletRequest;
import org.springframework.web.context.ContextLoader;
import javax.servlet.ServletContext;
import com.service.TokenService;
import com.utils.*;
import java.lang.reflect.InvocationTargetException;

import com.service.DictionaryService;
import org.apache.commons.lang3.StringUtils;
import com.annotation.IgnoreAuth;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.entity.*;
import com.entity.view.*;
import com.service.*;
import com.utils.PageUtils;
import com.utils.R;
import com.alibaba.fastjson.*;

/**
 * 图书
 * 后端接口
 * @author
 * @email
*/
@RestController
@Controller
@RequestMapping("/tushu")
public class TushuController {
    private static final Logger logger = LoggerFactory.getLogger(TushuController.class);

    @Autowired
    private TushuService tushuService;


    @Autowired
    private TokenService tokenService;
    @Autowired
    private DictionaryService dictionaryService;

    //级联表service

    @Autowired
    private DuzheService duzheService;


    /**
    * 后端列表
    */
    @RequestMapping("/page")
    public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){
        logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(false)
            return R.error(511,"永不会进入");
        else if("读者".equals(role))
            params.put("duzheId",request.getSession().getAttribute("userId"));
        params.put("tushuDeleteStart",1);params.put("tushuDeleteEnd",1);
        if(params.get("orderBy")==null || params.get("orderBy")==""){
            params.put("orderBy","id");
        }
        PageUtils page = tushuService.queryPage(params);

        //字典表数据转换
        List<TushuView> list =(List<TushuView>)page.getList();
        for(TushuView c:list){
            //修改对应字典表字段
            dictionaryService.dictionaryConvert(c, request);
        }
        return R.ok().put("data", page);
    }

    /**
    * 后端详情
    */
    @RequestMapping("/info/{id}")
    public R info(@PathVariable("id") Long id, HttpServletRequest request){
        logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
        TushuEntity tushu = tushuService.selectById(id);
        if(tushu !=null){
            //entity转view
            TushuView view = new TushuView();
            BeanUtils.copyProperties( tushu , view );//把实体数据重构到view中

            //修改对应字典表字段
            dictionaryService.dictionaryConvert(view, request);
            return R.ok().put("data", view);
        }else {
            return R.error(511,"查不到数据");
        }

    }

    /**
    * 后端保存
    */
    @RequestMapping("/save")
    public R save(@RequestBody TushuEntity tushu, HttpServletRequest request){
        logger.debug("save方法:,,Controller:{},,tushu:{}",this.getClass().getName(),tushu.toString());

        String role = String.valueOf(request.getSession().getAttribute("role"));
        if(false)
            return R.error(511,"永远不会进入");

        Wrapper<TushuEntity> queryWrapper = new EntityWrapper<TushuEntity>()
            .eq("tushu_uuid_number", tushu.getTushuUuidNumber())
            .eq("tushu_name", tushu.getTushuName())
            .eq("shujia_types", tushu.getShujiaTypes())
            .eq("tushu_types", tushu.getTushuTypes())
            .eq("tushu_zuozhe", tushu.getTushuZuozhe())
            .eq("tushu_chubanshe", tushu.getTushuChubanshe())
            .eq("tushu_kucun_number", tushu.getTushuKucunNumber())
            .eq("shangxia_types", tushu.getShangxiaTypes())
            .eq("tushu_delete", tushu.getTushuDelete())
            ;

        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        TushuEntity tushuEntity = tushuService.selectOne(queryWrapper);
        if(tushuEntity==null){
            tushu.setShangxiaTypes(1);
            tushu.setTushuDelete(1);
            tushu.setCreateTime(new Date());
            tushuService.insert(tushu);
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 后端修改
    */
    @RequestMapping("/update")
    public R update(@RequestBody TushuEntity tushu, HttpServletRequest request){
        logger.debug("update方法:,,Controller:{},,tushu:{}",this.getClass().getName(),tushu.toString());

        String role = String.valueOf(request.getSession().getAttribute("role"));
//        if(false)
//            return R.error(511,"永远不会进入");
        //根据字段查询是否有相同数据
        Wrapper<TushuEntity> queryWrapper = new EntityWrapper<TushuEntity>()
            .notIn("id",tushu.getId())
            .andNew()
            .eq("tushu_uuid_number", tushu.getTushuUuidNumber())
            .eq("tushu_name", tushu.getTushuName())
            .eq("shujia_types", tushu.getShujiaTypes())
            .eq("tushu_types", tushu.getTushuTypes())
            .eq("tushu_zuozhe", tushu.getTushuZuozhe())
            .eq("tushu_chubanshe", tushu.getTushuChubanshe())
            .eq("tushu_kucun_number", tushu.getTushuKucunNumber())
            .eq("shangxia_types", tushu.getShangxiaTypes())
            .eq("tushu_delete", tushu.getTushuDelete())
            ;

        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        TushuEntity tushuEntity = tushuService.selectOne(queryWrapper);
        if("".equals(tushu.getTushuPhoto()) || "null".equals(tushu.getTushuPhoto())){
                tushu.setTushuPhoto(null);
        }
        if(tushuEntity==null){
            tushuService.updateById(tushu);//根据id更新
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }

    /**
    * 删除
    */
    @RequestMapping("/delete")
    public R delete(@RequestBody Integer[] ids){
        logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
        ArrayList<TushuEntity> list = new ArrayList<>();
        for(Integer id:ids){
            TushuEntity tushuEntity = new TushuEntity();
            tushuEntity.setId(id);
            tushuEntity.setTushuDelete(2);
            list.add(tushuEntity);
        }
        if(list != null && list.size() >0){
            tushuService.updateBatchById(list);
        }
        return R.ok();
    }


    /**
     * 批量上传
     */
    @RequestMapping("/batchInsert")
    public R save( String fileName){
        logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);
        try {
            List<TushuEntity> tushuList = new ArrayList<>();//上传的东西
            Map<String, List<String>> seachFields= new HashMap<>();//要查询的字段
            Date date = new Date();
            int lastIndexOf = fileName.lastIndexOf(".");
            if(lastIndexOf == -1){
                return R.error(511,"该文件没有后缀");
            }else{
                String suffix = fileName.substring(lastIndexOf);
                if(!".xls".equals(suffix)){
                    return R.error(511,"只支持后缀为xls的excel文件");
                }else{
                    URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);//获取文件路径
                    File file = new File(resource.getFile());
                    if(!file.exists()){
                        return R.error(511,"找不到上传文件,请联系管理员");
                    }else{
                        List<List<String>> dataList = PoiUtil.poiImport(file.getPath());//读取xls文件
                        dataList.remove(0);//删除第一行,因为第一行是提示
                        for(List<String> data:dataList){
                            //循环
                            TushuEntity tushuEntity = new TushuEntity();
//                            tushuEntity.setTushuUuidNumber(data.get(0));                    //图书编号 要改的
//                            tushuEntity.setTushuName(data.get(0));                    //图书名称 要改的
//                            tushuEntity.setTushuPhoto("");//照片
//                            tushuEntity.setShujiaTypes(Integer.valueOf(data.get(0)));   //书架 要改的
//                            tushuEntity.setTushuTypes(Integer.valueOf(data.get(0)));   //图书类型 要改的
//                            tushuEntity.setTushuZuozhe(data.get(0));                    //图书作者 要改的
//                            tushuEntity.setTushuChubanshe(data.get(0));                    //出版社 要改的
//                            tushuEntity.setTushuKucunNumber(Integer.valueOf(data.get(0)));   //图书库存 要改的
//                            tushuEntity.setShangxiaTypes(Integer.valueOf(data.get(0)));   //是否上架 要改的
//                            tushuEntity.setTushuDelete(1);//逻辑删除字段
//                            tushuEntity.setTushuContent("");//照片
//                            tushuEntity.setCreateTime(date);//时间
                            tushuList.add(tushuEntity);


                            //把要查询是否重复的字段放入map中
                                //图书编号
                                if(seachFields.containsKey("tushuUuidNumber")){
                                    List<String> tushuUuidNumber = seachFields.get("tushuUuidNumber");
                                    tushuUuidNumber.add(data.get(0));//要改的
                                }else{
                                    List<String> tushuUuidNumber = new ArrayList<>();
                                    tushuUuidNumber.add(data.get(0));//要改的
                                    seachFields.put("tushuUuidNumber",tushuUuidNumber);
                                }
                        }

                        //查询是否重复
                         //图书编号
                        List<TushuEntity> tushuEntities_tushuUuidNumber = tushuService.selectList(new EntityWrapper<TushuEntity>().in("tushu_uuid_number", seachFields.get("tushuUuidNumber")).eq("tushu_delete", 1));
                        if(tushuEntities_tushuUuidNumber.size() >0 ){
                            ArrayList<String> repeatFields = new ArrayList<>();
                            for(TushuEntity s:tushuEntities_tushuUuidNumber){
                                repeatFields.add(s.getTushuUuidNumber());
                            }
                            return R.error(511,"数据库的该表中的 [图书编号] 字段已经存在 存在数据为:"+repeatFields.toString());
                        }
                        tushuService.insertBatch(tushuList);
                        return R.ok();
                    }
                }
            }
        }catch (Exception e){
            return R.error(511,"批量插入数据异常,请联系管理员");
        }
    }





    /**
    * 前端列表
    */
    @IgnoreAuth
    @RequestMapping("/list")
    public R list(@RequestParam Map<String, Object> params, HttpServletRequest request){
        logger.debug("list方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));

        // 没有指定排序字段就默认id倒序
        if(StringUtil.isEmpty(String.valueOf(params.get("orderBy")))){
            params.put("orderBy","id");
        }
        PageUtils page = tushuService.queryPage(params);

        //字典表数据转换
        List<TushuView> list =(List<TushuView>)page.getList();
        for(TushuView c:list)
            dictionaryService.dictionaryConvert(c, request); //修改对应字典表字段
        return R.ok().put("data", page);
    }

    /**
    * 前端详情
    */
    @RequestMapping("/detail/{id}")
    public R detail(@PathVariable("id") Long id, HttpServletRequest request){
        logger.debug("detail方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
        TushuEntity tushu = tushuService.selectById(id);
            if(tushu !=null){


                //entity转view
                TushuView view = new TushuView();
                BeanUtils.copyProperties( tushu , view );//把实体数据重构到view中

                //修改对应字典表字段
                dictionaryService.dictionaryConvert(view, request);
                return R.ok().put("data", view);
            }else {
                return R.error(511,"查不到数据");
            }
    }


    /**
    * 前端保存
    */
    @RequestMapping("/add")
    public R add(@RequestBody TushuEntity tushu, HttpServletRequest request){
        logger.debug("add方法:,,Controller:{},,tushu:{}",this.getClass().getName(),tushu.toString());
        Wrapper<TushuEntity> queryWrapper = new EntityWrapper<TushuEntity>()
            .eq("tushu_uuid_number", tushu.getTushuUuidNumber())
            .eq("tushu_name", tushu.getTushuName())
            .eq("shujia_types", tushu.getShujiaTypes())
            .eq("tushu_types", tushu.getTushuTypes())
            .eq("tushu_zuozhe", tushu.getTushuZuozhe())
            .eq("tushu_chubanshe", tushu.getTushuChubanshe())
            .eq("tushu_kucun_number", tushu.getTushuKucunNumber())
            .eq("shangxia_types", tushu.getShangxiaTypes())
            .eq("tushu_delete", tushu.getTushuDelete())
            ;
        logger.info("sql语句:"+queryWrapper.getSqlSegment());
        TushuEntity tushuEntity = tushuService.selectOne(queryWrapper);
        if(tushuEntity==null){
            tushu.setTushuDelete(1);
            tushu.setCreateTime(new Date());
        tushuService.insert(tushu);
            return R.ok();
        }else {
            return R.error(511,"表中有相同数据");
        }
    }


}

5.2 读者功能实现

5.2.1 图书信息

图5.6 即为编码实现的图书信息界面,读者在该界面中借阅图书,在界面底部对该界面的图书进行留言,同时可以点击界面右上角的收藏按钮对图书进行收藏。

图5.6 图书信息界面

大家点赞、收藏、关注、评论啦  其他的定制服务 商务合作  下方联系卡片↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓ 或者私信作者

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

翰文编程

你的鼓励 是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值