-
2020-07-11 14:47:21
作者: IT学长,从事软件开发 努力在IT搬砖路上的技术小白
公众号: 【IT学长】,分享计算机类毕业设计源码、IT技术文章、游戏源码、网页模板、程序人生等等。公众号回复 【粉丝】进博主技术群,与大佬交流,领取干货学习资料
关于转载:欢迎转载博主文章,转载时表明出处
求赞环节:创作不易,记得 点赞+评论+转发 谢谢你一路支持计算机类毕设源码大全:十几套计算机专业毕业设计文档及源码分享
系统演示链接:点击这里查看演示
运行教程:基于Web的图书管理系统运行教程
源码下载:微信搜索公众号【IT学长】,回复“基于web的图书管理系统”
文章目录
01 系统简述
图书管理系统就是利用计算机,结合互联网对图书进行结构化、自动化管理的一种软件,来提高对图书的管理效率。本系统采用Java+Servlet+Jsp 的方式实现基于web的图书管理系统。
02 开发工具及相关技术
2.1 Java技术
Java 是由 Sun Microsystems 在 1995 年首先发布的编程语言和计算平台。有许多应用程序和 Web 站点只有在安装 Java 后才能正常工作,而且这样的应用程序和 Web 站点日益增多。Java 快速、安全、可靠。从笔记本电脑到数据中心,从游戏控制台到科学超级计算机,从手机到互联网,Java 无处不在。
2.2 HTML、css、javascript技术
HTML的英文全称是 Hypertext Marked Language,即超文本标记语言。HTML是由Web的发明者 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 用户端–图书查询模块
用户访问图书查询模块时显示当前可以借阅图书,有按图书名称查询图书信息的功能,可以进行借书操作。
其中查询功能的Servlet代码如下: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.2 用户端–借阅信息模块
当普通用户借阅完图书,会在该模块自动生成借阅信息,如借阅日期,归还日期,也可在该模块进行还书,如下图所示。
其中,还书功能的Servlet代码如下: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.3 管理员端–图书管理模块
管理员可以通过根据图书号 、图书名称,作者名称,出版社等查询图书信息。
管理员登录系统以后,可以进行图书添加操作,这是管理员主要的输入信息部分,填写好各项信息后,单击保存按钮,系统将对这些信息进行处理。界面见下图所示:
除此以外,管理员对已经添加好的图书信息有修改权限。
其中,添加图书功能的代码如下: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 管理员端–图书分类模块
管理员在该界面可以增加、删除、修改图书分类信息,操作效果如图。
修改图书分类功能的代码如下: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"); } }
更多相关内容 -
基于web图书管理系统
2014-05-06 22:38:37基于web图书管理系统,报告需求分析等等 -
基于Web图书管理系统设计实现分析.doc
2021-10-02 07:25:26基于Web图书管理系统设计实现分析.doc -
基于WEB图书管理系统设计与实现课程设计.pdf
2021-10-15 15:08:21基于WEB图书管理系统设计与实现课程设计 -
毕业论文(基于web的图书管理系统)
2020-01-30 19:12:38该论文详细的阐述了利用java建设基于web的图书管理系统的全过程,成功的获得了“良”的好成绩! 该论文详细的阐述了利用java建设基于web的图书管理系统的全过程,成功的获得了“良”的好成绩! -
基于web开发的图书管理系统
2017-07-08 13:59:54期末做软件工程课设写的, 没有使用任何框架, 采用MYsql数据库, 有四个表, 还有电子版课程报告进我的主页可以下载, 功能: 图书的借阅,图书的归还,用户注册, 图书的增删改查(管理员), 用户的删查(管理员... -
基于Java Web图书管理系统课程设计
2020-07-08 21:18:29大二的Java Web课程设计,图书管理系统,基于HTML+CSS+JavaScript+JSP+Servlet+JavaBean+JDBC+DAO的Web架构设计,里面有课程设计报告,源代码,演示视频,数据库文件,超级详细哦 -
php基于WEB图书管理系统
2009-08-14 14:56:38基于WEB图书管理系统,用php+mysql完成,主要有图书检索,图书查讯等模块 -
基于web的图书管理系统.zip
2021-04-27 16:03:49jsp+servlet+tomcat 的图书管理系统。支持用户端和管理员端,功能齐全,适合课设。 简单易部署 -
基于Java web的图书管理系统源码(含数据库脚本).zip
2022-03-18 00:11:54源码参考,亲测有效,欢迎下载 -
基于WEB的图书管理系统_答辩PPT
2015-12-21 17:48:37PPT 详细的描述了基于WEB的图书管理系统的建设过程,本系统采用java技术实现,在答辩过程中,给老师留下了深刻的印象 -
基于web的图书馆管理系统的设计与实现毕业设计
2020-08-17 18:09:43系统设计利用了Java语言,SSM框架,MYSQL数据库,Eclipse开发工具实现了一个基于web的图书馆管理系统。 -
基于Java Web的图书馆管理系统
2021-10-23 17:25:14内容: 1.代码 2.数据库(access) 3....功能: 1. 图书类别信息管理:管理员登陆系统后可以对图书类别进行添加,更新和... 图书归还管理:当读者看完了书或需要归还时,管理员通过系统提供的接口完成图书归还操作。 -
基于web开发的图书管理系统(还有数据库源码)
2017-07-30 11:10:07期末做软件工程课设写的, 没有使用任何框架, 采用MYsql数据库, 有四个表, 还有电子版课程报告进我的主页可以下载, 功能: 图书的借阅,图书的归还,用户注册, 图书的增删改查(管理员), 用户的删查(管理员... -
基于Vue+Vant+SSM图书管理系统设计毕业论文源码
2021-06-17 15:25:24基于Vue图书管理app技术要点: 1 此系统web端接口采用java语言和ssm框架实现,可以升级Springboot 2 客户端和服务器通信采用axios组件,格式采用封装好的json数据格式 3 实现了图书的添加,修改,删除以及更加关键词... -
基于Java Web的图书销售管理系统(源代码+课程设计报告)
2019-12-30 19:57:58基于Java Web的图书销售管理系统 项目描述 本系统是基于jsp的网上图书销售,有比较符合初学者的简单而又不单一的界面,也有繁琐而又不过于抽象的后台数据处理。包含分类的登录用户(用户与管理员权限与界面不一)... -
基于Python Django实现的图书管理系统含全部源代码和设计报告.rar
2021-07-09 23:24:48# 图书管理系统说明V2.0 ### 项目介绍及再版说明(2016-01-24) 其实一开始做这个小项目在2014年的9到11月,当时是作为加入Pureweber开发组的大作业完成的。虽然用了两个月的时间,但是做出的东西还是有很多的... -
基于Web服务的图书管理系统的设计与实现.zip
2010-03-30 15:26:00基于Web服务的图书管理系统的设计与实现.zip -
基于Javaweb图书管理系统.zip
2021-01-03 00:35:31系统共分为三种用户: 1.普通用户 书籍查询、书籍借阅、书籍归还、书籍预定 2.管理员 借书处理、归还处理、预定处理 3.系统管理员 用户管理、书籍管理、类别管理 -
基于WEB的图书管理系统.doc
2019-07-01 17:07:43随着社会的发展,人们对知识的需求也不断的增长,在这种形势下,书籍就慢慢地成为人们获取并增长知识的主要途径,如何更好地管理图书关系到求知者阅读书籍的方便程度,所以开发出一套完善的图书管理系统就必不可少了... -
基于Javaweb的图书馆管理系统设计与实现(开题报告+论文).doc
2021-10-27 11:03:301.2目前图书管理系统存在的问题 1 1.3课题意义 1 1.4论文的工作和安排 2 2.图书借阅管理需求分析 3 2.1 可行性分析 3 2.1.1.技术可行性 3 2.1.2.经济可行性 3 2.2 图书借阅管理系统需求概述 3 2.2.1系统目标 3 2.2.2... -
基于SSH框架的WEB图书管理系统
2016-05-11 21:46:58开发工具是:Myeclipse+Tomcat+MySQL+SSH -
基于WEB图书管理系统
2008-04-20 15:09:23毕业设计,源代码,很好的软件 -
基于javaweb开发的图书管理系统
2018-03-11 23:10:35课程设计的一般项目,本系统是基于javaweb的后台图书管理系统,用到前端layUi框架。数据库是用的是mysql数据库,在用户表中找到超级用户和密码就可以登录。 项目的使用: 解压项目,然后倒入,在做基本的修改就可... -
毕业论文基于Web的图书管理系统
2012-05-26 17:55:20毕业论文 图书管理系统 包括源代码、数据库、绘图、截图、论文、开题报告、任务书、中期检查表等等。采用技术ASP.NET、SQL Server 2005. -
基于javaweb、mysql的 图书管理系统
2021-05-19 12:50:12基于javaweb、mysql的 图书管理系统。此案例是基于JavaEE、mysql技术的图书管理系统。运用到了sessoin到页面间传值,新手上路,勿喷,可以借鉴。界面过于简单!! -
基于javaweb的图书管理系统.zip
2021-07-09 15:17:21实现验证码、注册、登陆、三角色 运行环境:tomcat9 mysql5.7 -
Javaweb图书管理系统的设计与实现图书管理系统的设计与实现.docx
2021-04-22 22:14:285.1.4图书管理 17 5.1.5网站信息管理 18 5.1.6系统管理员管理 18 5.2会员功能模块的实现 19 5.2.1会员登录界面 19 5.2.2会员主界面 19 5.2.3会员反馈界面 20 5.2.4会员图书借阅界面 21 5.3系统测试 22 5.3.1系统测试...