基于JSP和MySQL实现的图书馆系统

基于JSP和MySQL实现的图书馆系统 1,项目介绍 1,1 项目简介 使用jsp,layui,mysql完成的图书馆系统,包含用户图书借阅,图书管理员

本文包含相关资料包-----> 点击直达获取<-------

基于JSP和MySQL实现的图书馆系统

1.项目介绍

1.1 项目简介

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

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

  • 演示地址 :http://library.mingyuefusu.cn

  • 用户账号密码 :1805010219、1234

  • 图书管理员账号密码 :root、1234

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

1.2 项目详细介绍

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

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

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

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

1.2.1 用户模块

  • 查看公告 :能看到图书管理员发布的公告信息

  • 图书查看 :分页显示,能看到图书总览,能通过图书编号、图书名称、作者、存放位置、图书描述进行模糊查询

  • 个人违章信息(登录后) :个人历史违章信息与查询

  • 图书馆读者留言(登录后) :对图书馆的建议,或对书籍的评价

  • 查看借阅规则 :不同的规则有不同的借阅限定数量、限定时间、超期费用

  • 个人信息(登录后) :对个人信息的查看与登录密码的修改

  • 个人借阅信息(登录后) :对个人借阅记录的分页查看与查询

1.2.2 图书管理员模块

  • 借还图书 :帮助用户借阅图书,并判断符不符合借阅规则、返还图书时判断有没有超期,超期则输出超期费用再归还

  • 借阅报表 :分页显示所有借阅记录、能进行查询和输出结果到excel公告管理:能添加编辑和删除公告

  • 还书报表 :分页显示所有未还的书籍,能通过借阅证号、图书编号、借阅日期、截止日期等条件进行模糊查询

  • 个人信息修改 :修改个人信息、密码等

1.2.3 系统管理员模块

  • 书籍管理 :分页,新添图书,设置图书各种信息,编辑删除,通过编号、书名、作者、描述等进行搜索,输出结果到excel,并且能查看该书籍被谁借阅过

  • 分类管理 :分页显示,增删改书籍分类,书籍分类方便查阅整理

  • 借阅证管理 :分页显示所有借阅证,增删改查用户借阅证,查看该借阅证所有的借阅记录

  • 借阅规则管理 :能显示、编辑、删除所有借阅规则,借阅规则将决定该图书证能借阅什么图书馆的图书,能借多少本,能借多久以及超期每天的费用

  • 借阅信息查询 :分页显示,能条件查询超期没还的,根据编号、借阅证号、书籍编号、借阅日期等进行模糊查询,输出结果到excel等,系统管理员只能查询,不能增删改借阅信息,这个操作由图书管理员操作

  • 图书管理员管理 :对图书管理员进行增删改操作,但是不能修改原来的账号

  • 图书借阅统计 :通过折线图将图书馆近30天的每天借阅书籍数量直观的显示出来

1.2.4 sql表

共有十张数据库表,书籍表、借书记录表、留言表、系统管理员表、借阅证表、图书管理管理员表书籍分类表、图书馆表、借阅规则表、公告表

  • 书籍表 :编号、姓名、作者、存放的图书馆、分类编号、存放位置、是否借出、书籍描述

  • 借书记录表 :编号、借阅证编号、书籍编号、借书日期、限制日期、归还日期、违规描述、处理人编号

  • 留言表 :编号、借阅证编号、留言内容、留言日期

  • 系统管理员表 :账号、密码

  • 借阅证表 :编号、密码、借阅者姓名、规则编号、状态(丢失、可用)

  • 图书管理员表 :编号、姓名、账号、密码、邮箱

  • 书籍分类表 :编号、分类名、分类描述

  • 图书馆表 :编号、图书馆名、描述

  • 规则表 :编号、限制借阅数量、限制借阅天数、图书超期每天费用

  • 公告表 :编号、标题、公告内容、发布日期

2.数据库设计

2.1 表结构

管理员表

公告表

分类表

图书表

借阅列表

用户表

图书馆表

工作人员表

评论表

借阅规则表

2.2 E-R图

3.项目开发

3.1 连接数据库

java public class DBConstants { public static final String driver = "com.mysql.cj.jdbc.Driver"; public static final String url = "jdbc:mysql://localhost:3306/library?&useSSL=false&serverTimezone=UTC&useUnicode=true&characterEncoding=UTF-8"; public static final String username = "root"; public static final String password = "root"; }

3.2 常用工具类

时间格式化工具类

java public class CompareDate { public static long show(String Str1, String Str2) { long between = 0; SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); try { Date date1 = format.parse(Str1); Date date2 = format.parse(Str2); between = (date2.getTime() - date1.getTime()); System.out.println(date1); System.out.println(date2); } catch (ParseException e) { // TODO Auto-generated catch block e.printStackTrace(); } long days = between / (24 * 60 * 60 * 1000); return days; }

字符过滤器

```java / * 字符过滤器 * @author Mingyue * / import javax.servlet. ; import java.io.IOException; public class CharacterEncodingFilter implements Filter { public void init(FilterConfig filterConfig) throws ServletException { }

public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
    servletRequest.setCharacterEncoding("UTF-8");
    servletResponse.setCharacterEncoding("UTF-8");
    filterChain.doFilter(servletRequest, servletResponse);
}

public void destroy() {
}

```

常用工具类

```java public class Util { /* * 主要用来计算json字符串中对象的个数 * @param str * @param contain * @return / public static int getCountString(String str, String contain) { int count = ( str.length()-str.replace(contain, "").length() ) / contain.length(); return count; }

/**
 * 数据库取出来的datetime有 .0 ,用来去掉
 * @param dateTime
 * @return
 */
public static String getFormatDateTime(String dateTime) {
    if(dateTime != null && dateTime.indexOf(".0") != -1) {
        return dateTime.substring(0, dateTime.length()-2);
    }else if(dateTime != null) {
        return dateTime;
    }
    return null;
}

/**
 * 获取当前时间
 * @return
 */
public static String getCurrentTimeString() {
    java.util.Date date = new java.util.Date();
    SimpleDateFormat dateFormat= new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    return dateFormat.format(date);
}

/*
 * 返回json数据
 */
public static String jsonResponse(int code, String msg, String data) {
    JSONObject jsonObject = new JSONObject();
    jsonObject.put("code", code);
    jsonObject.put("msg", msg);
    if( data!=null ) {
        jsonObject.put("data", data);
    }
    return jsonObject.toString();
}

/*
 * md5加密
 */
public static String stringToMD5(String plainText) {
    byte[] secretBytes = null;
    try {
        secretBytes = MessageDigest.getInstance("md5").digest(
                plainText.getBytes());
    } catch (NoSuchAlgorithmException e) {
        throw new RuntimeException("没有这个md5算法!");
    }
    String md5code = new BigInteger(1, secretBytes).toString(16);
    for (int i = 0; i < 32 - md5code.length(); i++) {
        md5code = "0" + md5code;
    }
    return md5code;
}

public static String passMd5(String password) {
    String salt = "ew!.E";
    return Util.stringToMD5(password +salt);
}

public static void main(String[] args) {
    System.out.println(Util.passMd5("admin"));
    //java.util.Date date = new java.util.Date();
    //SimpleDateFormat dateFormat= new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
    //System.out.println(dateFormat.format(date));
}

} ```

3.3 业务代码

```java @WebServlet("/manager/announcement") public class Announcement extends HttpServlet { @Override protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { resp.setContentType("application/json; charset=utf8"); // 准备数据 Connection connection = null; PreparedStatement pstmt = null; String sql = ""; ResultSet resultSet = null; // 返回数据 int code = 1; String msg = "无数据"; JSONObject jsonObject = new JSONObject(); JSONArray jsonArray = new JSONArray();

    try {
        connection = (Connection) Base.getConnection();
        sql = "select * from announcement";
        pstmt = connection.prepareStatement(sql);
        resultSet = pstmt.executeQuery();
        while (resultSet.next()) {
            jsonObject.put("id", resultSet.getString("id"));
            jsonObject.put("title", resultSet.getString("title"));
            jsonObject.put("detail", resultSet.getString("detail"));
            jsonObject.put("publish_date", resultSet.getString("publish_date"));

            jsonArray.add(jsonObject);
        }
        if (!jsonArray.isEmpty()) {
            code = 0;
            msg = "查询成功";
        } else {
            msg = "数据为空";
        }
    } catch (ClassNotFoundException e) {
        msg = "class找不到";
    } catch (SQLException e) {
        msg = "sql错误";
    } finally {
        try {
            Base.closeResource(connection, pstmt, resultSet);
        } catch (SQLException e) {
            msg = "关闭失败";
        }
    }
    PrintWriter out = resp.getWriter();
    out.print(Util.jsonResponse(code, msg, jsonArray.toString()));
}

} ```

4.部署

下载压缩包,或者使用 git clone 下载(使用 git checkout maven 可以更换为分支maven,其使用maven进行依赖管理,更便于运行部署)

将library.sql文件导入mysql数据库,并修改以下文件的数据库连接相关属性(数据库账号密码、数据库表名)

5.项目演示

5.1 用户

图书查询

5.2 图书管理员

5.3 系统管理员

参考文献

  • 数字图书馆中跨库检索系统研究(兰州大学·何显华)
  • 基于SSH架构的高校自助化图书管理系统的设计与实现(大连理工大学·杨议)
  • 基于JSP的网上书店系统的设计与实现(吉林大学·马新)
  • 基于JSP的实验室项目管理系统的设计与实现(武汉理工大学·吕勇)
  • 吉林大学图书馆随书光盘管理系统的设计与实现(吉林大学·刘剑锋)
  • 复旦大学数字图书馆个人图书管理系统的设计与实现(电子科技大学·陆卫国)
  • 基于B/S架构的图书管理系统(山东大学·彭鹏)
  • 基于J2EE的图书管理系统的分析与设计(吉林大学·李妍)
  • 高校图书管理系统的设计与实现(东北大学·黄鑫)
  • 基于JSP的高校图书管理系统开发和实现(电子科技大学·朱丽萍)
  • 基于B/S架构的图书管理系统的设计与实现(山东大学·蒲琼)
  • 基于Web的图书管理系统的设计与实现(西安电子科技大学·丁侃)
  • 基于JSP的实验室项目管理系统的设计与实现(武汉理工大学·吕勇)
  • 基于SSH三层架构的数字图书馆设计与实现(华中科技大学·张甲)
  • 图书综合管理系统(吉林大学·王宇)

本文内容包括但不限于文字、数据、图表及超链接等)均来源于该信息及资料的相关主题。发布者:毕业设计驿站 ,原文地址:https://m.bishedaima.com/yuanma/35538.html

相关推荐

发表回复

登录后才能评论