基于web的图书管理系统设计与实现(可作为 毕业设计、课程设计 附演示地址)

  • 2.4 Eclipse开发工具

  • 2.5 MySql数据库

  • 03 系统功能描述

  • 04 工程结构及其说明

  • 05 主要功能详细设计与实现

      • 5.1 用户端–图书查询模块
  • 5.2 用户端–借阅信息模块

  • 5.3 管理员端–图书管理模块

  • 5.4 管理员端–图书分类模块

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数据库有以下特点:

  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 用户端–图书查询模块

用户访问图书查询模块时显示当前可以借阅图书,有按图书名称查询图书信息的功能,可以进行借书操作。

在这里插入图片描述

其中查询功能的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 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 {

自学几个月前端,为什么感觉什么都没学到??


这种现象在很多的初学者和自学前端的同学中是比较的常见的。

因为自学走的弯路是比较的多的,会踩很多的坑,学习的过程中是比较的迷茫的。

最重要的是,在学习的过程中,不知道每个部分该学哪些知识点,学到什么程度才算好,学了能做什么。

很多自学的朋友往往都是自己去找资料学习的,资料上有的或许就学到了,资料上没有的或许就没有学到。

这就会给人一个错误的信息就是,我把资料上的学完了,估计也-就差不多的了。

但是真的是这样的吗?非也,因为很多人找的资料就是很基础的。学完了也就是掌握一点基础的东西。分享给你一份前端分析路线,你可以参考。

还有很多的同学在学习的过程中一味的追求学的速度,很快速的刷视频,写了后面忘了前面,最后什么都没有学到,什么都知道,但是什么都不懂,要具体说,也说不出个所以然。

所以学习编程一定要注重实践操作,练习敲代码的时间一定要多余看视频的时间。

  • 21
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值