Проектирование и внедрение системы управления книгами на основе java springboot

Java задняя часть
Проектирование и внедрение системы управления книгами на основе java springboot

Это 17-й день моего участия в августовском испытании обновлений. Ознакомьтесь с подробностями мероприятия: Испытание августовского обновления

предисловие

С развитием сетевых технологий и значительным улучшением уровня компьютерных приложений исходная система имеет недостатки в своевременности, правильности данных и удобстве работы, что повлияло на нормальное использование системы. После исследования и сравнения я решил самостоятельно перепроектировать систему управления книгами, чтобы система могла использовать достижения технологии разработки программного обеспечения для облегчения управления книгами. Система управления библиотекой представляет собой типичную систему управления информацией. Система знакомит с процессом разработки книжной системы, проблемами, возникающими при проектировании, и решениями, а также с улучшением текущего приложения или хода разработки системы и повышением производительности труда. Используя различные инструменты объектно-ориентированной разработки, которые он предоставляет, он сначала создает прототип системного приложения за короткий период времени, а затем итерирует первоначальный прототип системы, постоянно пересматривает и улучшает его до тех пор, пока не будет создана осуществимая система, которая удовлетворит пользователей. сформировался.
Этот дизайн курса использует инструменты разработки JAVA и базу данных Mysql для разработки этой системы управления книгами. Система должна решать проблемы, решаемые управлением книгами, и может отвечать основным требованиям управления книгами, включая такие функции, как добавление и управление. Система может быстро и удобно предоставлять читателям услуги заимствования в соответствии с потребностями пользователей.

фоновое значение


С широким распространением компьютеров он постепенно стал символом модернизации. Библиотеки или некоторые предприятия, или даже книжные магазины, всегда сталкиваются с большим объемом информации о читателе, информации о книгах и информации о заимствовании и возврате книг, генерируемых взаимодействием этих двух факторов в процессе нормальной работы. Следовательно, необходимо управлять ресурсами читателей, ресурсами книг, заимствованием информации и возвратом информации о книгах, быть в курсе изменений информации в каждой ссылке и своевременно обрабатывать полученные документы.Автоматическое управление булавками может удовлетворить требования читателей быстрее и повысить эффективность различных работ, и в настоящее время разработана соответствующая система. Основной функцией системы управления библиотекой является автоматизация управления выдачей и возвратом библиотечных книг. Вокруг этой основной функции система включает следующие основные функции: управление кредитами, управление возвратами. В дополнение к этим основным функциям он также включает в себя некоторые основные и вспомогательные функции, а именно: управление пользователями, управление книгами, запрос книг.

 

Дизайн базы данных

пользовательская таблица

CREATE TABLE `NewTable` (
`admin_id`  int(11) NOT NULL AUTO_INCREMENT ,
`admin_name`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
`admin_pwd`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
`admin_email`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
PRIMARY KEY (`admin_id`)
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=2
ROW_FORMAT=DYNAMIC
;

Список книг

CREATE TABLE `NewTable` (
`book_id`  int(11) NOT NULL AUTO_INCREMENT ,
`book_name`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL ,
`book_author`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
`book_publish`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
`book_category`  int(11) NULL DEFAULT NULL ,
`book_price`  double NULL DEFAULT NULL ,
`book_introduction`  varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
PRIMARY KEY (`book_id`),
FOREIGN KEY (`book_category`) REFERENCES `book_category` (`category_id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
INDEX `book_category` (`book_category`) USING BTREE 
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=72
ROW_FORMAT=DYNAMIC
;

Тип книги

CREATE TABLE `NewTable` (
`category_id`  int(11) NOT NULL AUTO_INCREMENT ,
`category_name`  varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL ,
PRIMARY KEY (`category_id`)
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=51
ROW_FORMAT=DYNAMIC
;

Выдача книг

CREATE TABLE `NewTable` (
`id`  int(11) NOT NULL AUTO_INCREMENT ,
`user_id`  int(11) NULL DEFAULT NULL ,
`book_id`  int(11) NULL DEFAULT NULL ,
`date`  date NULL DEFAULT NULL ,
PRIMARY KEY (`id`),
FOREIGN KEY (`book_id`) REFERENCES `book` (`book_id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
FOREIGN KEY (`user_id`) REFERENCES `user` (`user_id`) ON DELETE RESTRICT ON UPDATE RESTRICT,
INDEX `user_id` (`user_id`) USING BTREE ,
INDEX `book_id` (`book_id`) USING BTREE 
)
ENGINE=InnoDB
DEFAULT CHARACTER SET=utf8 COLLATE=utf8_general_ci
AUTO_INCREMENT=67
ROW_FORMAT=DYNAMIC
;

Функциональный скриншот

Авторизоваться:

Пользователь выбирает роль и вводит пароль учетной записи для входа в систему.

титульная страница:

Основные модули после входа в систему:

Управление книгами «Ввод новых книг, управление типами, запрос данных»

Управление пользователями «Добавить пользователя, запросить пользователя»

Управление займами «Кредитные отчеты»

Просмотр личной информации, изменение и выход и т. д.

Управление книгами:

 

Управление пользователями:

Управление займами:

Персональная информация:

пользовательский терминал

После входа в систему пользователи могут просматривать свои записи о заимствовании и выполнять такие операции, как заимствование и возврат книг.

Код

       Функционал этого проекта относительно прост, а используемая технология также хорошо всем знакома, в основном это springboot, springmvc, mybatis и базовые стили, такие как jquery, layui, html и css во внешнем интерфейсе. Возьмем логин в качестве полного примера.Во-первых, нужно написать статическую страницу внешнего интерфейса и отправить запрос на вход.

<!DOCTYPE html>
<html lang="zh-CN" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>


    <link rel="stylesheet" th:href="@{/layui/css/layui.css}">
    <style>

        body {
            /*width: 100%;*/
            /*height: 100%;*/
            background: url("/images/background.png") no-repeat;
            /*background: url("static/images/a.png") no-repeat;*/
            background-size: cover;
        }

        #login_form {
            width: 400px;
            height: 300px;
            margin: 80px auto;
            padding: 30px;
            background-color: #f2f2f2;
            opacity: 0.9;
        }

    </style>
</head>
<body>

<div id="wrapper" style="margin-top: 260px">
    <div class="layui-container" id="login_form">

        <div>
            <h1 style="color: red;text-align: center">图书管理系统</h1>
            <br>
        </div>

        <form class="layui-form" id="my_form" method="post" action="/userLogin">

            <div class="layui-form-item">
                <label class="layui-form-label">用户名:</label>
                <div class="layui-input-block">
                    <input type="text" name="userName" id="username" autofocus
                           placeholder="请输入用户名" autocomplete="off" class="layui-input">
                </div>
            </div>

            <div class="layui-form-item">
                <label class="layui-form-label">密 码:</label>
                <div class="layui-input-block">
                    <input type="password" name="password" id="password"
                           placeholder="请输入密码" autocomplete="off" class="layui-input">
                </div>
            </div>


            <div class="layui-form-item">
                <label class="layui-form-label">用户身份</label>
                <div class="layui-input-block">
                    <input class="form-check-input" type="radio" name="role" value="1" title="学生" checked>
                    <input class="form-check-input" type="radio" name="role" value="0" title="管理员">
                </div>
            </div>

            <div class="layui-form-item layui-col-md4 layui-col-md-offset4">
                <button id="sub_btn" class="layui-btn layui-btn-normal">登录</button>
            </div>

        </form>

    </div>
</div>


<script th:src="@{/scripts/jquery.min.js}"></script>
<script th:src="@{/layui/layui.js}"></script>


<script th:inline="javascript">
    layui.use(['layer', 'form'], function () {
        let layer = layui.layer;
        let form = layui.form;
        form.render();

        $(function () {
            let flag = [[${session.flag}]];
            if (flag) {
                layer.msg("用户名或密码错误", {
                    icon: 2,
                    time: 2000 //2秒关闭(如果不配置,默认是3秒)
                });
            }
        });
    });


    $("#sub_btn").click(function () {
        let username = $("#username").val();
        let user_judge = check(username);

        // 首先判断用户名是否为空
        if (user_judge) {
            let password = $("#password").val();
            let pwd_judge = check(password);

            // 用户名不为空  , 判断密码是否为空
            if (pwd_judge) {
                let role_id = $('input[name="role"]:checked').val();

                // 如果role_id ==1 ,则是普通用户 , 直接提交表单
                if (role_id == 1) {
                    $("#my_form").submit();
                } else {

                    //如果是管理员 , 则将action 进行更改
                    $("#my_form").attr("action", "/adminLogin")
                    $("#my_form").submit();
                }

            } else {
                layer.alert("密码不能为空", {icon: 5});
                return false;
            }
        } else {

            layer.alert("用户名不能为空", {icon: 5});
            return false;
        }
    });

    // 校验表单中用户名 与 密码是否输入,  如果有值 -> 返回 true , 如果未输入 返回 false;
    function check(val) {
        val = val.toString().trim();
        return !(val == '');
    }

</script>
</body>
</html>

    После получения запроса на вход от внешнего интерфейса внутренний контроллер выполняет проверку параметров, оценивает и проверяет имя пользователя, пароль и роль пользователя, переданные внешним интерфейсом, вызывает метод userService.userLogin для выполнения проверки входа пользователя, запросы правильность текущего пароля учетной записи в базе данных и возврат кода состояния.Выполнение относительных переходов страниц и эффектов данных для внешнего интерфейса и внешнего интерфейса в соответствии с кодом состояния.

/**
     * 用户登录
     *
     * @param userName
     * @return
     */
    @PostMapping("/userLogin")
    public String userLogin(@Param("userName") String userName,
                            @Param("password") String password, HttpServletRequest request) {
        User user = userService.userLogin(userName, password);
        if (null != user) {
            // flag = 0 表示用户名密码校验成功  【用于前端校验】
            request.getSession().setAttribute("flag", 0);

            request.getSession().setAttribute("user", user);
            return "user/index";
        }

        // flag 为 1 表示 登录失败 【用于前端校验】
        request.getSession().setAttribute("flag", 1);
        return "index";
    }

Вообще говоря, функция этого проекта относительно проста и превосходна, подходит для начинающих в качестве эталона для дизайна курса и дизайна выпускного.