JavaWeb图书管理系统设计与实现(附源码)

文章目录

    • [01 系统简述](#01 系统简述)
    • [02 开发工具及相关技术](#02 开发工具及相关技术)
      • [2.1 Java技术](#2.1 Java技术)
      • [2.2 HTML、css、javascript技术](#2.2 HTML、css、javascript技术)
      • [2.3 Servlet技术](#2.3 Servlet技术)
      • [2.4 Eclipse开发工具](#2.4 Eclipse开发工具)
      • [2.5 MySql数据库](#2.5 MySql数据库)
    • [03 系统功能描述](#03 系统功能描述)
    • [04 工程结构及其说明](#04 工程结构及其说明)
    • [05 主要功能展示及部分源码](#05 主要功能展示及部分源码)
      • [5.1 登录](#5.1 登录)
      • [5.2 管理员端-首页](#5.2 管理员端-首页)
      • [5.3 管理员端--图书管理](#5.3 管理员端--图书管理)
      • [5.4 管理员端--图书分类管理](#5.4 管理员端--图书分类管理)
      • [5.5 管理员端--图书借阅信息](#5.5 管理员端--图书借阅信息)
      • [5.6 管理员端--图书归还信息](#5.6 管理员端--图书归还信息)
      • [5.7 管理员端--公告管理](#5.7 管理员端--公告管理)
      • [5.8 管理员端--读者管理](#5.8 管理员端--读者管理)
      • [5.9 用户端--首页](#5.9 用户端--首页)
      • [5.10 用户端--图书查询](#5.10 用户端--图书查询)
      • [5.11 用户端--借阅信息](#5.11 用户端--借阅信息)
      • [5.12 用户端--借阅历史](#5.12 用户端--借阅历史)
      • [5.13 用户端--我的](#5.13 用户端--我的)
    • [06 源码下载](#06 源码下载)
    • [07 运行教程](#07 运行教程)

01 系统简述

图书管理系统是一种借助计算机设备,融合网络技术对图书资源实施规范化、智能化管控的应用程序,其目的在于提升图书管理的工作效率。本系统运用Java+Servlet+Jsp+MySQL 的技术组合,构建了一套基于Web架构的图书管理平台。

02 开发工具及相关技术

2.1 Java技术

Java是由Sun Microsystems公司于1995年首次推出的编程语言与计算平台。众多应用程序及Web网站均需安装Java环境方可正常运行,且此类应用与站点的数量仍在持续增长。Java具备高效、安全、稳定的特性。无论是个人笔记本电脑还是大型数据中心,从游戏主机到科研超级计算机,从移动终端到互联网领域,Java的应用遍及各个角落。

2.2 HTML、css、javascript技术

HTML的英文全称为Hypertext Marked Language,中文意为超文本标记语言。HTML由万维网创始人Tim Berners-Lee及其同事Daniel W. Connolly于1990年共同创建,属于一种标记语言,是标准通用标记语言SGML的具体应用。采用HTML编写的超文本文档被称作HTML文档,该文档能够兼容各类操作系统平台(例如UNIX、Windows等)。借助HTML语言,用户可按照特定规则将所需呈现的信息编写为HTML文件,经由专用浏览器进行解析,并将这些HTML文件"转换"为可识别的内容,即当前所浏览的网页界面。

层叠样式表(英文全称:Cascading Style Sheets)是一种用于展现HTML(标准通用标记语言的一种应用)或XML(标准通用标记语言的子集)等文件外观样式的计算机语言。CSS不仅能够对网页进行静态美化,还可配合多种脚本语言实现网页各元素的动态格式化。CSS 能够对网页中元素位置的排版实现像素级精准控制,兼容几乎所有字体字号样式,具备对网页对象及模型样式进行编辑处理的能力。

JavaScript(简称"JS")是一种以函数为优先的轻量级、解释型或即时编译型编程语言。尽管它以开发Web页面脚本语言而闻名,但其实际应用已扩展至诸多非浏览器环境。JavaScript是一种基于原型编程、支持多范式的动态脚本语言,兼容面向对象、命令式以及声明式(如函数式编程)等多种编程风格。JavaScript于1995年由Netscape公司的Brendan Eich在网景导航者浏览器上首次设计并实现。由于Netscape与Sun公司存在合作关系,Netscape管理层期望其外观与Java相似,故将其命名为JavaScript。然而,其实际语法风格更接近Self及Scheme语言。JavaScript的规范标准为ECMAScript。截至2012年,所有浏览器均已完整支持ECMAScript 5.1标准,早期版本的浏览器至少支持ECMAScript 3标准。2015年6月17日,ECMA国际组织正式发布了ECMAScript的第六版,该版本官方名称为 ECMAScript 2015,但通常被称为ECMAScript 6或ES6。

2.3 Servlet技术

Servlet(Server Applet)是Java Servlet的简称,亦称为小服务程序或服务连接器,是采用Java语言编写的服务器端程序,具有跨平台及跨协议的独立特性,其核心功能在于实现交互式数据浏览与生成,进而构建动态Web内容。

从狭义角度而言,Servlet是指Java语言实现的一个接口;从广义角度而言,Servlet是指所有实现了该Servlet接口的类。通常情况下,人们将Servlet理解为后者。Servlet运行于支持Java的应用服务器环境中。从原理层面分析,Servlet能够响应各类请求,但在实际应用中,绝大多数情况下Servlet仅用于扩展基于HTTP协议的Web服务器功能。

2.4 Eclipse开发工具

Eclipse是一款开源的、基于Java语言的可扩展开发平台。就其本质而言,它仅是一个框架及一组服务,用于通过插件组件来搭建开发环境。值得庆幸的是,Eclipse自带了一套标准的插件集合,其中包含Java开发工具(Java Development Kit,JDK)。

2.5 MySql数据库

MySql是目前最为流行的关系型数据库管理系统,在WEB应用领域,MySQL堪称最佳的RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之一。MySql数据库具备以下特性:

  1. Mysql为开源软件,因此无需支付额外费用。
  2. Mysql能够支持大型数据库,可处理包含上千万条记录的大规模数据库。
  3. MySQL采用标准的SQL数据语言格式。
  4. Mysql可运行于多个操作系统之上,且支持多种编程语言。这些编程语言涵盖C、C++、Python、Java、Perl、PHP、Eiffel、Ruby以及Tcl等。
  5. Mysql对PHP具有良好的支持,PHP是当前最为流行的Web开发语言。
  6. MySQL支持大型数据库,可承载5000万条记录的数据仓库,32位系统下表文件最大支持4GB,64位系统下最大支持的表文件可达8TB。
  7. Mysql支持定制化开发,采用GPL协议,用户可修改源代码以构建专属的Mysql系统。

03 系统功能描述

本系统的用户群体主要分为两类:第一类为图书管理系统的管理员,第二类为普通用户。依据用户角色的差异,系统将功能模块划分为普通用户端与管理员端,两端各自具备的主要功能如下:

用户端

图书查询:支持按照图书编号、图书名称检索图书信息,可获取图书的编号、名称、分类、作者、价格、在馆数量等信息。

借阅信息:可查看图书的基本信息、借阅日期、应还书截止日期、超期天数等内容。

借阅历史:可检索个人过往的借阅记录,包括所借图书的具体详情等信息。

我的:支持查看个人资料、修改账户密码、退出系统等操作。

管理员端

图书管理:支持按照图书编号、图书名称查询图书基本信息,并具备添加、修改、删除图书的功能。

图书分类管理:支持按照分类名称查询图书分类信息,并具备添加、修改、删除图书分类的功能。

图书借阅:展示当前所有处于借阅状态的图书信息。

图书归还:展示当前所有已完成归还的图书信息。

公告管理:支持向用户发布系统公告。

读者管理:支持按照账号、姓名查询读者基本信息,并具备添加、修改、删除读者信息的功能。

我的:支持查看个人资料、修改账户密码、退出系统等操作。

04 工程结构及其说明

项目名称:manage_books

Package包说明:

05 主要功能展示及部分源码

5.1 登录

5.2 管理员端-首页

5.3 管理员端--图书管理

管理员可通过图书号、图书名称、作者名称、出版社等条件检索图书信息。

管理员登录系统后,可执行图书添加操作,此为管理员核心的信息录入环节,填写完毕各项信息后,点击保存按钮,系统将对所填信息进行处理。界面展示如下:

此外,管理员对已录入的图书信息拥有修改权限。

其中,添加图书功能的代码如下:

java 复制代码
package com.cya.controller;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.cya.dao.BookDao;
/**
 * Servlet implementation class AddBookServlet
 */
@WebServlet("/AddBookServlet")
public class AddBookServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public AddBookServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
//        response.getWriter().append("Served at: ").append(request.getContextPath());
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
//        doGet(request, response);
        //设置编码类型
        request.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        //获取要添加图书的信息
        String card = request.getParameter("card");
        String name = request.getParameter("name");
        String type = request.getParameter("type");
        String autho = request.getParameter("autho");
        String press = request.getParameter("press");
        int num = Integer.parseInt(request.getParameter("num"));
        BookDao bookdao = new BookDao();
        //调用函数,存入图书
        bookdao.addBook(card, name, type, autho, press, num);
        response.sendRedirect("/manage_books/books/admin/admin_books.jsp");
    }

}

5.4 管理员端--图书分类管理

管理员在该界面可执行增加、删除、修改图书分类信息的操作,效果如图所示。

修改图书分类功能的代码如下:

java 复制代码
package com.cya.controller;
import java.io.IOException;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.cya.dao.BookDao;
import com.cya.dao.TypeDao;
/**
 * Servlet implementation class updateBookTypeServlet
 */
@WebServlet("/updateBookTypeServlet")
public class updateBookTypeServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public updateBookTypeServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
//        response.getWriter().append("Served at: ").append(request.getContextPath());
    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
//        doGet(request, response);
        //修改图书类型信息
        request.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        String name = request.getParameter("name");
        int tid = Integer.parseInt(request.getParameter("tid"));
        TypeDao typedao = new TypeDao();
        typedao.updateTypeBook(tid, name);
        response.sendRedirect("/manage_books/books/admin/admin_booksType.jsp");
    }

}

5.5 管理员端--图书借阅信息

5.6 管理员端--图书归还信息

5.7 管理员端--公告管理

5.8 管理员端--读者管理

5.9 用户端--首页

5.10 用户端--图书查询

用户访问图书查询模块时,页面将展示当前可借阅的图书列表,支持按照图书名称检索图书信息,并可执行借书操作。

其中查询功能的Servlet代码如下:

java 复制代码
package com.cya.controller;
import java.io.IOException;
import java.util.ArrayList;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import com.cya.dao.BookDao;
import com.cya.pojo.Book;
/**
 * Servlet implementation class selectServlet
 */
@WebServlet("/selectServlet")
public class selectServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public selectServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
       //response.getWriter().append("Served at: ").append(request.getContextPath());

    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
       //doGet(request, response);
        request.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        //因为在管理员界面和读者界面都有查找功能,为了将查找的结果返回正确的页面,设置了tip,tip=1表示管理员界面
        int tip = Integer.parseInt(request.getParameter("tip"));
        String name = request.getParameter("name");
        BookDao bookdao = new BookDao();
        ArrayList<Book> data = bookdao.getLikeList(name);
        //将获取的结果存入请求中
        request.setAttribute("data", data);
        String url = "";
        //转发不同的界面
        if (tip == 1) {
            url = response.encodeURL("/books/admin/admin_books.jsp");
        } else {
            url = response.encodeURL("/books/user/select.jsp");
        }
        //将请求转发
        request.getRequestDispatcher(url).forward(request, response);
    }

}

5.11 用户端--借阅信息

当普通用户完成图书借阅后,该模块将自动生成借阅记录,包含借阅日期、归还日期等信息,用户也可在此模块执行还书操作,如下图所示。

其中,还书功能的Servlet代码如下:

java 复制代码
package com.cya.controller;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import com.cya.pojo.Admin;
import com.cya.dao.AdminDao;
import com.cya.dao.BookDao;
/**
 * Servlet implementation class borrowServlet
 */
@WebServlet("/borrowServlet")
public class borrowServlet extends HttpServlet {
    private static final long serialVersionUID = 1L;

    /**
     * @see HttpServlet#HttpServlet()
     */
    public borrowServlet() {
        super();
        // TODO Auto-generated constructor stub
    }

    /**
     * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
       //response.getWriter().append("Served at: ").append(request.getContextPath());
        //设置编码类型
        request.setCharacterEncoding("UTF-8");
        response.setContentType("text/html;charset=UTF-8");
        BookDao bookdao = new BookDao();
        //为了区分借书和还书的功能,设置tip,tip为1,表示借书
        int tip = Integer.parseInt(request.getParameter("tip"));
        if (tip == 1) {
            //获取图书id
            int bid = Integer.parseInt(request.getParameter("bid"));
            HttpSession session = request.getSession();
            Admin admin = new Admin();
            String status=request.getParameter("status");
            String id="";
            if(status.equals("user")) {
                //获取到存入session的读者id
                id = (String) session.getAttribute("uid");
            }
            else {
                //获取到存入session的aid读者id
                 id = (String) session.getAttribute("aid");
            }

            AdminDao admindao = new AdminDao();
            //通过aid获取到读者的信息
            admin = admindao.get_AidInfo2(id);
            //将借阅记录存入数据表
            bookdao.borrowBook(bid, admin);
            response.sendRedirect("/manage_books/books/user/select.jsp");
        } else {
            //还书功能,获取借阅记录的hid
            int hid = Integer.parseInt(request.getParameter("hid"));
            /**
             * 还书在管理员和读者界面都有,为了区分,设置了show字段,show为1表示读者界面
             */
            int show = Integer.parseInt(request.getParameter("show"));
            //调用还书函数,改变status字段
            bookdao.borrowBook2(hid);
            if (show == 1) {
                response.sendRedirect("/manage_books/books/user/borrow.jsp");
            } else {
                response.sendRedirect("/manage_books/books/admin/admin_borrows.jsp");
            }

        }

    }

    /**
     * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
     */
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        // TODO Auto-generated method stub
        doGet(request, response);
    }

}

5.12 用户端--借阅历史

5.13 用户端--我的

06 源码下载

源码下载:微信搜索公众号【IT学长】,回复关键词"基于Web的图书管理系统"下载源码

07 运行教程

详细运行步骤及常见问题解答请参阅"基于Web的图书管理系统"源码包中的README.md文件。

通过第6步下载源码包并解压后如下图所示:

本期内容到此结束,感谢您的阅读。

相关推荐
秋91 小时前
MySQL 8.4.9 LTS 与 MySQL 9.7.0 LTS 全方位深度对比
数据库·mysql
HUGu RGIN10 小时前
MySQL--》如何在MySQL中打造高效优化索引
android·mysql·adb
DevilSeagull16 小时前
MySQL(2) 客户端工具和建库
开发语言·数据库·后端·mysql·服务
远洪17 小时前
claude code 国内安装使用
数据库·mysql
wangbing112520 小时前
MySQL 官方 GPG 密钥过期问题
数据库·mysql
重生之我是Java开发战士20 小时前
【MySQL】事务 & 用户与权限管理
android·数据库·mysql
计算机_毕业设计20 小时前
java-springboot数字藏品系统 基于 SpringBoot 的区块链数字艺术品交易平台 Java 微服务架构下的加密藏品展示与拍卖系统计算机毕业设计
java·spring boot·课程设计
2401_8955213421 小时前
MySQL中的count函数
数据库·mysql
.小小陈.21 小时前
MySQL 入门到实战:从基础概念到核心存储引擎
数据库·mysql