文章目录
-
- [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数据库具备以下特性:
- Mysql为开源软件,因此无需支付额外费用。
- Mysql能够支持大型数据库,可处理包含上千万条记录的大规模数据库。
- MySQL采用标准的SQL数据语言格式。
- Mysql可运行于多个操作系统之上,且支持多种编程语言。这些编程语言涵盖C、C++、Python、Java、Perl、PHP、Eiffel、Ruby以及Tcl等。
- Mysql对PHP具有良好的支持,PHP是当前最为流行的Web开发语言。
- MySQL支持大型数据库,可承载5000万条记录的数据仓库,32位系统下表文件最大支持4GB,64位系统下最大支持的表文件可达8TB。
- 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步下载源码包并解压后如下图所示:

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