作者主页:源码空间站2022

简介:Java领域优质创作者、Java项目、学习资料、技术互助

文末获取源码

项目介绍

使用jsp+servlet、layui、mysql完成的图书馆系统,包含用户图书借阅、图书管理员、系统管理员界面,功能齐全。

开发工具为eclipse/IDEA,环境java8,tomcat9.0+,mysql为5.7(mysql8也行)

项目详细介绍

本图书管理系统总体上分为前台页面显示和后台管理。

前台页面(即本书图书管理系统的首页)实现了公告的显示,图书查询,留言建议三大主要功能,有读者规则查看功能,师生们可以看到图书管理人员发布的最新公告信息,并可以查询自己感兴趣的图书,查看留言提议,用户登录后还有个人资料修改、个人借阅信息查询、个人违章信息查询等功能,也可以给学校的图书管理人员留言提议。

后台的页面则集成了图书管理中所需的功能,分成图书管理人员和系统管理人员,平时管理人员的工作都是在后台中完成的。前台是为了师生显示的。相对应的后台是针对学校图书管理人员,后台的页面都加密,如果不正常登录是进入不了后台管理页面的,后台图书管理人员功能包括:借阅图书、归还图书、借书记录显示与查找、还书记录显示与查找、公告增删改查;后台系统管理员功能包括:对书籍的增删改查、对书籍分类的增删改、对借阅证的增删改查、对借阅信息的显示与查找、对借阅规则的增删改、对图书管理员的增删改、对近期借阅书籍数量的折线图显示,以及对这些表格数据进行Excel表格的输出

共包含三个大模块:用户、图书管理员、系统管理员

一、用户模块

1. 查看公告:能看到图书管理员发布的公告信息。
2. 图书查看:分页显示,能看到图书总览,能通过图书编号、图书名称、作者、存放位置、图书描述进行模糊查询
3. 个人违章信息(登录后):个人历史违章信息与查询
4. 图书馆读者留言(登录后):对图书馆的建议,或对书籍的评价
5. 查看借阅规则:不同的规则有不同的借阅限定数量、限定时间、超期费用
6. 个人信息(登录后):对个人信息的查看与登录密码的修改
7. 个人借阅信息(登录后):对个人借阅记录的分页查看与查询

二、图书管理员模块

1. 借还图书:帮助用户借阅图书,并判断符不符合借阅规则、返还图书时判断有没有超期,超期则输出超期费用再归还
2. 借阅报表:分页显示所有借阅记录、能进行查询和输出结果到excel公告管理:能添加编辑和删除公告
3. 还书报表:分页显示所有未还的书籍,能通过借阅证号、图书编号、借阅日期、截止日期等条件进行模糊查询
4. 个人信息修改:修改个人信息、密码等

三、系统管理员模块

1. 书籍管理:分页,新添图书,设置图书各种信息,编辑删除,通过编号、书名、作者、描述等进行搜索,输出结果到excel,并且能查看该书籍被谁借阅过。
2. 分类管理:分页显示,增删改书籍分类,书籍分类方便查阅整理
3. 借阅证管理:分页显示所有借阅证,增删改查用户借阅证,查看该借阅证所有的借阅记录
4. 借阅规则管理:能显示、编辑、删除所有借阅规则,借阅规则将决定该图书证能借阅什么图书馆的图书,能借多少本,能借多久以及超期每天的费用。
5. 借阅信息查询:分页显示,能条件查询超期没还的,根据编号、借阅证号、书籍编号、借阅日期等进行模糊查询,输出结果到excel等,系统管理员只能查询,不能增删改借阅信息,这个操作由图书管理员操作。
6. 图书管理员管理:对图书管理员进行增删改操作,但是不能修改原来的账号
7. 图书借阅统计:通过折线图将图书馆近30天的每天借阅书籍数量直观的显示出来。

sql表

共有十张数据库表,书籍表、借书记录表、留言表、系统管理员表、借阅证表、图书管理管理员表书籍分类表、图书馆表、借阅规则表、公告表
- 书籍表
- 编号、姓名、作者、存放的图书馆、分类编号、存放位置、是否借出、书籍描述
- 借书记录表
- 编号、借阅证编号、书籍编号、借书日期、限制日期、归还日期、违规描述、处理人编号
- 留言表
- 编号、借阅证编号、留言内容、留言日期
- 系统管理员表
- 账号、密码
- 借阅证表
- 编号、密码、借阅者姓名、规则编号、状态(丢失、可用)
- 图书管理员表
- 编号、姓名、账号、密码、邮箱
- 书籍分类表
- 编号、分类名、分类描述
- 图书馆表
- 编号、图书馆名、描述
- 规则表
- 编号、限制借阅数量、限制借阅天数、图书超期每天费用
- 公告表
- 编号、标题、公告内容、发布日期

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 9.x版本,注:tomcat9.0以下会有问题;
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.是否Maven项目: 否;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目

6.数据库:MySql 5.7版本,(mysql8也行)

技术栈

1. 后端:JSP+Servlet

2. 前端:jsp+layui+bootstrap+jQuery

使用说明

1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;若为maven项目,导入成功后请执行maven clean;maven install命令,配置tomcat,然后运行;
3. 将项目中src/javabean/Base.java和JDBCBean.java配置文件中的数据库配置改为自己的配置;
4. 运行项目,输入localhost:8080/xxx 登录
5. 用户账号密码:1805010219    1234
图书管理员账号密码:root  1234

系统管理员账号密码:admin admin

运行截图

相关代码

Admin

package javabean;import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;import net.sf.json.JSONArray;
import net.sf.json.JSONObject;public class Admin {/*** 用户登录* * @param username* @param password* @return* @throws ClassNotFoundException* @throws SQLException*/@SuppressWarnings("null")public String login(String username, String password) throws ClassNotFoundException, SQLException {if (username == null || username.trim().equals("")) {return "账号不能为空";} else if (password == null || password.trim().equals("")) {return "密码不能为空";}Connection connection = null;PreparedStatement pstmt = null;ResultSet resultSet = null;String sql = "select * from admin where username=? and password=? limit 1";connection = Base.getConnection();pstmt = (PreparedStatement) connection.prepareStatement(sql);pstmt.setString(1, username);pstmt.setString(2, Util.passMd5(password));resultSet = pstmt.executeQuery();try{if (resultSet.next()) {return "1";}}catch(Exception e) {return "发生未知错误";}finally {if(Base.closeResource(connection, pstmt, resultSet) == false) {return "关闭失败";}}return "账号或密码错误";}/*** 获取图书列表* @param page* @param limit* @return String json字符串* @throws ClassNotFoundException* @throws SQLException*/public Map getBookList(String page, String limit, Map where) throws ClassNotFoundException, SQLException {Map<String, Object> map = new HashMap<String, Object>();String whereString = "";Connection connection = null;PreparedStatement pstmt = null;ResultSet resultSet = null;connection = Base.getConnection();int number = Integer.valueOf(page);int size = Integer.valueOf(limit); String sql = "select * from books ";if(where!=null && !where.isEmpty()) {whereString += " where "+where.get("condition") +" like '%" +where.get("conditionValue") +"%' ";sql += whereString;}sql += "order by id desc limit ?,? ";pstmt = (PreparedStatement) connection.prepareStatement(sql);pstmt.setInt(1, (number-1) * size );pstmt.setInt(2, size);resultSet = pstmt.executeQuery();JSONObject json = new JSONObject();String result = "";int i = 1;// 获取行数据while( resultSet.next() ) {//System.out.println("????-------" +resultSet.getInt("count"));json.put("id", resultSet.getInt("id"));json.put("name", resultSet.getString("name"));json.put("author", resultSet.getString("author"));json.put("library_id", resultSet.getInt("library_id"));json.put("sort_id", resultSet.getInt("sort_id"));json.put("position", resultSet.getString("position"));json.put("status", resultSet.getInt("status"));json.put("description", resultSet.getString("description"));if(i==1) {result = json.toString();}else {result += "," +json.toString();}i++;}map.put("data", result);// 获取总数count,重写sqlint count = 0;sql = "select count(*) as count  from books ";if(where!=null && !where.isEmpty()) {sql += whereString;}pstmt = connection.prepareStatement(sql);resultSet = pstmt.executeQuery();if(resultSet.next()) {count = resultSet.getInt("count");}map.put("count", count);Base.closeResource(connection, pstmt, resultSet);return map;}/*** 通过id(String)获取分类名称* @param id* @return* @throws ClassNotFoundException* @throws SQLException*/public static String getSortName(String id) throws ClassNotFoundException, SQLException {if(id==null || id.equals(""))return "参数错误";Connection connection = null;PreparedStatement pstmt = null;ResultSet resultSet = null;String sql = null;String result = null;connection =  Base.getConnection();sql = "select name from book_sort where id=?";pstmt = connection.prepareStatement(sql);pstmt.setString(1, id);resultSet = pstmt.executeQuery();if(resultSet.next()) {result = resultSet.getString("name");}else {result = "查询失败";}Base.closeResource(connection, pstmt, null);return result;}/*** 根据id获取书籍信息* @param id* @return* @throws ClassNotFoundException* @throws SQLException*/public static ResultSet getBookInfo(int id) throws ClassNotFoundException, SQLException {Connection connection = null;PreparedStatement pstmt = null;ResultSet resultSet = null;String sql = "select * from books where id=? ";connection = Base.getConnection();pstmt = connection.prepareStatement(sql);pstmt.setInt(1, id);resultSet = pstmt.executeQuery();//Base.closeResource(null, null, null);connection.close();if(resultSet.next()) {return resultSet;}return null;}/* 没用 */public static JSONArray getRules() throws ClassNotFoundException, SQLException {Connection connection = null;PreparedStatement pstmt = null;ResultSet resultSet = null;String sql = "select * from rules";JSONObject jsonObject = new JSONObject();JSONArray jsonArray = new JSONArray();String result = "";connection = Base.getConnection();pstmt = connection.prepareStatement(sql);resultSet = pstmt.executeQuery();while(resultSet.next()) {jsonObject.put("id", resultSet.getString("id"));jsonObject.put("borrow_num", resultSet.getString("borrow_num"));jsonObject.put("borrow_library", resultSet.getString("borrow_library"));jsonObject.put("overtime_fee", resultSet.getString("overtime_fee"));jsonArray.add(jsonObject);System.out.println(jsonArray.toString());}Base.closeResource(connection, pstmt, resultSet);return jsonArray;}public static void main(String[] args) throws ClassNotFoundException, SQLException {//Common common = new Common();//System.out.println(common.getCount("books"));Admin admin = new Admin();System.out.println(admin.getSortName("2"));//Map map =  admin.getBookList("1", "100");//System.out.println( map.get("count"));}
}

Base

package javabean;import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;public class Base {private static String driver = "com.mysql.cj.jdbc.Driver";private static String url = "jdbc:mysql://localhost:3306/library?useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8";private static String username = "root";private static String password = "root";/*** 获取数据库连接* * @return* @throws ClassNotFoundException*/public static Connection getConnection() throws ClassNotFoundException {Connection connection = null;try {Class.forName(driver);connection = (Connection) DriverManager.getConnection(url, username, password);} catch (SQLException e) {e.printStackTrace();}return connection;}/*** 公共查询* * @param connection*            连接* @param preparedStatement* @param resultSet*            结果集* @param sql* @param params* @return* @throws SQLException*/public static ResultSet executequery(Connection connection, PreparedStatement preparedStatement,ResultSet resultSet, String sql, Object[] params) throws SQLException {if (preparedStatement == null) {preparedStatement = (PreparedStatement) connection.prepareStatement(sql);}for (int i = 0; params != null && i < params.length; i++) {preparedStatement.setObject(i + 1, params[i]);}resultSet = preparedStatement.executeQuery();return resultSet;}/*** 公共修改方法* * @param connection* @param preparedStatement* @param sql* @param params* @return* @throws SQLException*/public static int executeUpdate(Connection connection, PreparedStatement preparedStatement, String sql,Object[] params) throws SQLException {if (preparedStatement == null) {preparedStatement = (PreparedStatement) connection.prepareStatement(sql);}for (int i = 0; params != null && i < params.length; i++) {preparedStatement.setObject(i + 1, params[i]);}int updateRows = preparedStatement.executeUpdate();return updateRows;}/*** 释放资源* * @param connection* @param preparedStatement* @param resultSet* @return* @throws SQLException*/public static boolean closeResource(Connection connection, PreparedStatement preparedStatement, ResultSet resultSet)throws SQLException {boolean flag = true;if (resultSet != null) {try {resultSet.close();resultSet = null;} catch (SQLException e) {e.printStackTrace();flag = false;}}if (preparedStatement != null) {try {preparedStatement.close();preparedStatement = null;} catch (SQLException e) {e.printStackTrace();flag = false;}}if (connection != null) {try {connection.close();connection = null;} catch (SQLException e) {e.printStackTrace();flag = false;}}return flag;}}

如果也想学习本系统,下面领取。关注并回复:011jsp

Java项目:jsp+servlet图书管理系统相关推荐

  1. jsp+servlet图书管理系统

    项目介绍 使用jsp+servlet.layui.mysql完成的图书馆系统,包含用户图书借阅.图书管理员.系统管理员界面,功能齐全. 开发工具为eclipse/IDEA,环境java8,tomcat ...

  2. 程序逸的Java项目之旅-图书管理系统之验证码和用户数据的后台获取(1)

    通过上篇博客>>>>>程序逸的Java项目之旅-图书管理系统之后端接口的快速实现,我们就可以快速搭建出基础的项目代码了,今天我们就先来实现一个验证码和后台获取管理员的账号 ...

  3. 程序逸的Java项目之旅-图书管理系统之数据库设计(1)

    程序逸的Java项目之旅-图书管理系统之环境的搭建 1.前言 上篇博客我们介绍了一下环境的搭建,我相信很多小伙伴这点应该问题不大,可能就是idea破解和mysql数据库和redis数据库的安装吧,我其 ...

  4. 程序逸的Java项目之旅-图书管理系统之数据库设计(2-完)

    紧接上篇博客>>>>>>程序逸的Java项目之旅-图书管理系统之数据库设计(1) 4.数据库表的创建 对于数据库表,我们可以通过cmd窗口进行创建,但那种方法有点麻 ...

  5. Java项目:SpringBoot图书管理系统

    作者主页:夜未央5788 简介:Java领域优质创作者.Java项目.学习资料.技术互助 文末获取源码 项目介绍 本系统分为管理员与普通用户两种角色: 管理员角色包含以下功能: 借书管理,图书信息管理 ...

  6. Java程序员的福音:Java项目教学之图书管理系统(含源代码)

    1 图书管理系统项目演示 图书管理系统分析: 定义Book类 完成主界面和选择 完成查询所有图书 完成添加图书 完成删除图书 完成修改图书 使用Debug追踪调试 2 图书管理系统之标准Book类 我 ...

  7. java+mysql+jsp+servlet 幼儿园管理系统

    项目:基于JSP的幼儿园信息管理系统 相关技术:java.mysql.jsp.servlet 项目角色:教师.会计.园长.学生家长 项目要求:        1.可以进行登陆注册        2.完 ...

  8. 程序逸的Java项目之旅-图书管理系统之环境的搭建

    其实自己一直没有真正的梳理过一个项目,无论这个项目是简单还是困难,所以我希望通过这个项目帮助我学习以及分享自己的心得给大家,谢谢. 1.前言 这个项目我也是从零开始写,并且更新的速度要看我写的速度,期 ...

  9. 程序逸的Java项目之旅-图书管理系统之项目搭建

    前两篇博客将数据库表简单设计了一下,接下来我们就可以先搭建项目基础的骨架了.很多高校依旧使用eclipse/myeclipse来作为编译器,不是说这个编译器不好,其实Ieda的功能它都有,但用起来就是 ...

最新文章

  1. windows7 端口查看以及杀死进程释放端口
  2. 家校通Android源码,基于Android的家校通系统设计与实现
  3. docker 容器状态 restarting_20分钟极简入门Docker
  4. python 操作 excel
  5. 云计算适用于中小企业吗?
  6. 记住:用户不是傻*,她是你的老婆大人
  7. 对于PHP框架的简单认识
  8. 拦截器---SpringMVC(权限拦截)
  9. linux内核怎么修改屏幕旋转方向_树莓派4—屏幕旋转
  10. android socket 闪退,android客户端闪退
  11. NetCore游戏服务器GeekServer
  12. PhpStorm2017破解版
  13. win10打开语言服务器,在 Windows 10 中,部署一个 Go 1.13 语言的本地文档浏览 web 服务器的流程(已缺少 godoc.exe)...
  14. Chomsky文法分类
  15. 交换机链路聚合(静态,动态)
  16. STM32+ULN2003驱动步进电机
  17. 国内外顶级核心期刊TOP20
  18. 迅雷下载器无限制版_无敏感_无限速
  19. 8090该如何创业呢?
  20. Gartner:超级应用成为战略技术趋势,可以从中学习到什么

热门文章

  1. 没有大数据就没有智慧城市
  2. Tensorflow 进阶学习
  3. php mud游戏源码,从零开始构建PHP版mud游戏(三)
  4. 计算机绘图软件应用于哪些领域,解答电脑绘图软件有哪些
  5. Moto Z2F 使用体验 刷机经验分享
  6. 深度学习项目实战——木薯叶图像识别与分类项目
  7. 东航电商前端技术周刊第二期20180608
  8. spring boot 源码解析52-actuate中MVCEndPoint解析
  9. 网络技术| 说说计算机网络及IP地址 -- 网络基础 跳线制作 IP地址配置
  10. 锂电池供电电路设计方案汇总(四款设计方案)