java图书信息管理

一、项目概述

本图书信息管理系统旨在提供一个直观的用户界面,用于管理图书馆或书店的图书信息。系统包括图书添加、查询、借阅和归还等功能。

二、系统架构

系统采用JavaSwing作为前端UI框架,后端使用Java Servlet处理业务逻辑,数据存储在MySQL数据库中。

三、技术选型

  • 前端使用JavaSwing,提供直观用户界面。
  • 后端使用Java Servlet处理用户请求和数据库交互。
  • 数据库采用MySQL存储图书信息和借阅记录。

四、安装和配置

  1. 下载项目源代码。
  2. 安装Java Development Kit (JDK)。
  3. 设置数据库连接配置。
  4. 运行系统初始化脚本。

1.添加图书

  1. 进入主界面,选择“图书管理”。
  2. 点击“添加图书”按钮,输入图书信息,如书名、作者、出版社等。
  3. 确认添加图书。

2.查询图书

  1. 在主界面选择“查询图书”。
  2. 输入关键字,如书名或作者。
  3. 查看匹配的图书列表。

3.借阅图书

  1. 进入“借阅管理”模块。
  2. 选择要借阅的图书,输入借阅者信息。
  3. 确认借阅图书。

4.归还图书

  1. 进入“借阅管理”模块。
  2. 选择要归还的图书,输入借阅者信息。
  3. 确认归还图书。

5.查看借阅历史

  1. 在主界面选择“借阅历史”。
  2. 输入借阅者信息或图书信息。
  3. 查看借阅历史记录。

五、数据库设计

感谢提供数据库文件。以下是对这个数据库文件的简要说明:

book

  • BookId:图书ID,自增长。
  • BookName:图书名称。
  • Writter:作者。
  • BookType:图书类型。
  • Price:价格。
  • IsBorrow:是否借出。

borrow

  • BorrowId:借阅记录ID,自增长。
  • BookId:借阅的图书ID。
  • BookName:借阅的图书名称。
  • BookType:借阅的图书类型。
  • userid:借阅者ID。
  • username:借阅者用户名。
  • BorrowTime:借阅时间。
  • ReturnTime:归还时间。
  • IsReturn:是否归还。

root

  • rootID:管理员ID,自增长。
  • rootName:管理员用户名。
  • rootPWD:管理员密码。

user

  • userid:用户ID,自增长。
  • username:用户名。
  • userpsw:用户密码。
  • useremail:用户邮箱。
  • useraddr:用户地址。
  • userphone:用户电话。

这些表之间存在一些关联,比如 book 表和 borrow 表通过 BookId 关联。你可以使用这个数据库脚本初始化你的数据库。

六、程序截图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

七、代码

Login.java

package view;import java.awt.BorderLayout;
import java.awt.Color;
import java.awt.Container;
import java.awt.Font;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;import javax.swing.ButtonGroup;
import javax.swing.ImageIcon;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPanel;
import javax.swing.JPasswordField;
import javax.swing.JRadioButton;
import javax.swing.JTextField;import utils.DBUtil;public class LogIn extends JFrame {private JLabel labTitle = new JLabel("图书信息管理系统登录");private Font font = new Font("隶书", Font.BOLD, 34);private JButton btnSure = new JButton("登录");private JButton btnCancel = new JButton("重置");private JButton btnZhuce = new JButton("注册");private JPanel panBtn = new JPanel();private JLabel labLoginName = new JLabel("用户名:");private JLabel labPWD = new JLabel("密    码:");private JTextField jtfLoginName;private JPasswordField jpfPWD;private JPanel panMain = new JPanel();public LogIn() {setTitle("登录界面");// setDefaultLookAndFeelDecorated(true);this.setSize(500, 350);setLocationRelativeTo(null);setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);init();add(labTitle, BorderLayout.NORTH);add(panBtn, BorderLayout.SOUTH);add(panMain, BorderLayout.CENTER);}private void init() {labTitle.setFont(font);labTitle.setHorizontalAlignment(JLabel.CENTER);labTitle.setForeground(Color.RED);// labTitle.setBorder(BorderFactory.createLineBorder(Color.BLACK));labTitle.setBackground(Color.BLUE);// 单选框JRadioButton JB1 = new JRadioButton("管理员登录");JRadioButton JB2 = new JRadioButton("用户登录");// 加入组,避免出现可以两个都选择的情况ButtonGroup bg = new ButtonGroup();JB2.setSelected(true);// 默认选中'用户登录'jtfLoginName = new JTextField("", 10);jpfPWD = new JPasswordField(16);labLoginName.setSize(100, 40);labLoginName.setLocation(50, 50);labLoginName.setHorizontalAlignment(JLabel.RIGHT);labPWD.setSize(100, 40);labPWD.setLocation(50, 50 + 40 + 10);labPWD.setHorizontalAlignment(JLabel.RIGHT);jtfLoginName.setSize(200, 40);jtfLoginName.setLocation(50 + 100 + 20, 50);jpfPWD.setSize(200, 40);jpfPWD.setLocation(50 + 100 + 20, 50 + 40 + 10);jpfPWD.setEchoChar('*');JB1.setSize(90, 20);JB1.setLocation(125, 175);JB2.setSize(80, 20);JB2.setLocation(275, 175);btnSure.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent e) {if (JB2.isSelected()) {Statement stmt = DBUtil.getStatement();String name = jtfLoginName.getText().trim();String pwd = new String(jpfPWD.getPassword()).trim();String sql = "select * from user where username='" + name+ "' AND userpsw='" + pwd + "';";try {ResultSet rs = stmt.executeQuery(sql);if (rs.next()) {JOptionPane.showConfirmDialog(LogIn.this,"登陆成功,欢迎进入!", "登陆成功",JOptionPane.CLOSED_OPTION);dispose();new LibraryUserFrame().setVisible(true);LibraryUserFrame.USER_NAME = name;} else {JOptionPane.showMessageDialog(null, "账号或密码错误!");}} catch (SQLException e1) {e1.printStackTrace();}/** UserDao UD = new UserDao(); UserBean uBean =* UD.findUser(name, pwd); if (uBean != null) {* JOptionPane.showConfirmDialog(LogIn.this, "登陆成功,欢迎进入!",* "登陆成功", JOptionPane.CLOSED_OPTION); dispose();* LibraryUserFrame LU = new LibraryUserFrame();* LU.setVisible(true); LibraryUserFrame.USER_NAME = name;* }else { JOptionPane.showMessageDialog(null, "账号或密码错误!");* }*/} else {Statement stmt = DBUtil.getStatement();String name = jtfLoginName.getText().trim();String pwd = new String(jpfPWD.getPassword()).trim();String sql = "select * from root where rootName='" + name+ "' AND rootPWD='" + pwd + "';";try {ResultSet rs = stmt.executeQuery(sql);if (rs.next()) {JOptionPane.showConfirmDialog(LogIn.this,"登陆成功,欢迎进入!", "登陆成功",JOptionPane.CLOSED_OPTION);dispose();LibraryRootFrame LR = new LibraryRootFrame();LR.setVisible(true);LibraryRootFrame.USER_NAME = name;} else {JOptionPane.showMessageDialog(null, "账号或密码错误!");}} catch (SQLException e1) {e1.printStackTrace();}}}});btnCancel.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {jtfLoginName.setText("");jpfPWD.setText("");}});btnZhuce.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {dispose();new ZhuceFrame().setVisible(true);}});panBtn.add(btnSure);panBtn.add(btnCancel);panBtn.add(btnZhuce);// 把单选按钮加入组bg.add(JB1);bg.add(JB2);panMain.setLayout(null);panMain.add(labLoginName);panMain.add(labPWD);panMain.add(jtfLoginName);panMain.add(jpfPWD);panMain.add(JB1);panMain.add(JB2);ImageIcon img = new ImageIcon("image/ZhuCe.png");// 要设置的背景图片JLabel imgLabel = new JLabel(img);// 将背景图放在标签里。panMain.add(imgLabel, new Integer(Integer.MIN_VALUE));// 将背景标签添加到jfram的LayeredPane面板里。imgLabel.setBounds(0, 0, img.getIconWidth(), img.getIconHeight());// 设置背景标签的位置Container contain = this.getContentPane();((JPanel) contain).setOpaque(false);}public static void main(String[] args) {new LogIn().setVisible(true);}
}

LibraryUserFrame.java

package view;import java.awt.Container;
import java.awt.Dimension;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;public class LibraryUserFrame extends JFrame {public static String USER_NAME;public LibraryUserFrame() {this.setLayout(null);ImageIcon img = new ImageIcon("image/3.jpg");// 要设置的背景图片JLabel imgLabel = new JLabel(img);// 将背景图放在标签里。this.getLayeredPane().add(imgLabel, new Integer(Integer.MIN_VALUE));// 将背景标签添加到jfram的LayeredPane面板里。imgLabel.setBounds(0, 0, img.getIconWidth(), img.getIconHeight());// 设置背景标签的位置Container contain = this.getContentPane();((JPanel) contain).setOpaque(false);setSize(1000, 750);setTitle("图书馆管理系统_用户");setResizable(false); // 不可改变窗口大小// 获取屏幕大小和当前frame的大小Dimension thisScreen = Toolkit.getDefaultToolkit().getScreenSize();Dimension thisFrame = this.getSize();// 使启动窗口位于屏幕的正中心setLocation((thisScreen.width - thisFrame.width) / 2,(thisScreen.height - thisFrame.height) / 2);// 设置单击窗口的【关闭】按钮时将发生相应的动作setDefaultCloseOperation(EXIT_ON_CLOSE);JMenuBar menuBar = new JMenuBar(); // 创建菜单栏// 创建菜单JMenu j1 = new JMenu("书籍管理");JMenuItem j1_1 = new JMenuItem("搜索图书");j1_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new BookSearch().setVisible(true);}});JMenuItem j1_2 = new JMenuItem("查看所有图书");j1_2.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new AllBook().setVisible(true);}});JMenuItem j1_3 = new JMenuItem("借阅图书");j1_3.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new UserBorrow().setVisible(true);}});JMenuItem j1_4 = new JMenuItem("归还图书");j1_4.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new UserReturn().setVisible(true);}});j1.add(j1_1);j1.add(j1_2);j1.add(j1_3);j1.add(j1_4);JMenu j2 = new JMenu("个人中心");JMenuItem j2_1 = new JMenuItem("修改密码");j2_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new UserXiugaimima().setVisible(true);}});j2.add(j2_1);JMenu j3 = new JMenu("系统");JMenuItem j3_1 = new JMenuItem("注销登录");j3_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {dispose();new LogIn().setVisible(true);}});j3.add(j3_1);menuBar.add(j1);menuBar.add(j2);menuBar.add(j3);this.setJMenuBar(menuBar);}
}

LibraryRootFrame.java

package view;import java.awt.Container;
import java.awt.Dimension;
import java.awt.Toolkit;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JMenu;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;import Date.BarTest;
import Date.PieChart;
import Date.PieTest;public class LibraryRootFrame extends JFrame {public static String USER_NAME;public LibraryRootFrame() {this.setLayout(null);ImageIcon img = new ImageIcon("image/3.jpg");//要设置的背景图片JLabel imgLabel = new JLabel(img);//将背景图放在标签里。this.getLayeredPane().add(imgLabel, new Integer(Integer.MIN_VALUE));//将背景标签添加到jfram的LayeredPane面板里。imgLabel.setBounds(0, 0, img.getIconWidth(), img.getIconHeight());// 设置背景标签的位置Container contain = this.getContentPane();((JPanel) contain).setOpaque(false); setSize(1000, 730);setTitle("图书馆管理系统——管理员");setResizable(false); // 不可改变窗口大小// 获取屏幕大小和当前frame的大小Dimension thisScreen = Toolkit.getDefaultToolkit().getScreenSize();Dimension thisFrame = this.getSize();// 使启动窗口位于屏幕的正中心setLocation((thisScreen.width - thisFrame.width) / 2,(thisScreen.height - thisFrame.height) / 2);// 设置单击窗口的【关闭】按钮时将发生相应的动作setDefaultCloseOperation(EXIT_ON_CLOSE);JMenuBar menuBar = new JMenuBar(); // 创建菜单栏// 创建菜单JMenu j1 = new JMenu("书籍管理");JMenuItem J1_1 = new JMenuItem("添加书籍");J1_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new BookAddFrame().setVisible(true);}});JMenuItem J1_2 = new JMenuItem("更新和删除书籍");J1_2.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new Book_Update_Delete().setVisible(true);}});JMenuItem J1_3 = new JMenuItem("查找书籍");J1_3.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new BookSearch().setVisible(true);}});JMenuItem J1_4 = new JMenuItem("查看所有书籍");J1_4.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new AllBook().setVisible(true);}});j1.add(J1_1);j1.add(J1_2);j1.add(J1_3);j1.add(J1_4);JMenu j2 = new JMenu("用户管理");JMenuItem J2_1 = new JMenuItem("添加用户");J2_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new UserAddFrame().setVisible(true);}});JMenuItem J2_2 = new JMenuItem("更新和删除用户");J2_2.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new User_Update_Delete().setVisible(true);}});JMenuItem J2_3 = new JMenuItem("查询用户");J2_3.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new UserSearch().setVisible(true);}});j2.add(J2_1);j2.add(J2_2);j2.add(J2_3);JMenu j3 = new JMenu("借书记录");JMenu J3 = new JMenu("借书数据分析");JMenuItem J3_1 = new JMenuItem("饼形图查看");J3_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new PieTest().setVisible(true);}});JMenuItem J3_2 = new JMenuItem("条形图查看");J3_2.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new BarTest().setVisible(true);}});JMenuItem j3_1 = new JMenuItem("查看借书记录");j3_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new AllBorrow().setVisible(true);}});J3.add(J3_1);J3.add(J3_2);j3.add(J3);j3.add(j3_1);JMenu j4 = new JMenu("系统设置");JMenuItem j4_1 = new JMenuItem("修改密码");j4_1.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {new RootXiugaiMima().setVisible(true);}});JMenuItem j4_2 = new JMenuItem("注销登录");j4_2.addActionListener(new ActionListener() {@Overridepublic void actionPerformed(ActionEvent arg0) {dispose();new LogIn().setVisible(true);}});j4.add(j4_1);j4.add(j4_2);menuBar.add(j1);menuBar.add(j2);menuBar.add(j3);menuBar.add(j4);this.setJMenuBar(menuBar);}public static void main(String[] args) {new LibraryRootFrame().setVisible(true);}
}

八、交流与联系

q:969060742 文档、代码、sql

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/148516.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

一键智能视频编辑与视频修复算法——ProPainter源码解析与部署

前言 视频编辑和修复确实是随着电子产品的普及变得越来越重要的技能。有许多视频编辑工具可以帮助人们轻松完成这些任务如:Adobe Premiere Pro,Final Cut Pro X,Davinci Resolve,HitFilm Express,它们都提供一些视频修…

ipaguard界面概览

ipaguard界面分左右2块:左边菜单导航栏,右边的功能区 左侧菜单:按模块分成启动界面,代码模块,文件模块,重签名与测试模块 右侧主功能区会随着功能变化,但是整体分3块,顶部显示过滤区…

数据指标体系

一、初识指标体系构建 1.1 什么是指标体系 指标体系是一个比较抽象的概念,指标体系是衡量、评估和监测特定领域或目标的系统化指标的集合。它由多个指标组成,这些指标可以用于衡量和评估所关注领域或目标的各个方面。指标体系通常被用于监测和评估业务绩…

柯桥生活口语学习,英语中初次见面,除了Nice to meet you,还能说什么?

第一印象非常重要。所以当你第一次见到某人时,留下一个好印象很重要,尤其是当你面对一个重要的工作或者面对某个对你来说可能非常特别的人时。 下面我列出了一些最常用的说“很高兴见到你”的表达方法,也包括对方的回答,除了nice …

Kaggle - LLM Science Exam上:赛事概述、数据收集、BERT Baseline

文章目录 一、赛事概述1.1 OpenBookQA Dataset1.2 比赛背景1.3 评估方法和代码要求1.4 比赛数据集1.5 优秀notebook 二、BERT Baseline2.1 数据预处理2.2 定义data_collator2.3 加载模型,配置trainer并训练2.4 预测结果并提交2.5 相关优化 前言:国庆期间…

用于数据增强的十个Python库

数据增强是人工智能和机器学习领域的一项关键技术。它涉及到创建现有数据集的变体,提高模型性能和泛化。Python是一种流行的AI和ML语言,它提供了几个强大的数据增强库。在本文中,我们将介绍数据增强的十个Python库,并为每个库提供…

springmvc-国际化中英文切换文件上传下载

1. 国际化 1.1 介绍 国际化(internationalization), 简称国际化。一个产品支持国际化是指产品在无需做大的改变就能够适应不同的语言和地区的能力。i18n是指是一种让软件在开发阶段就支持多种语言的技术。 1.2 java.util.Locale 该类对象表示了特定的地理&#…

GET 和 POST的区别

GET 和 POST 是 HTTP 请求的两种基本方法,要说它们的区别,接触过 WEB 开发的人都能说出一二。 最直观的区别就是 GET 把参数包含在 URL 中,POST 通过 request body 传递参数。 你可能自己写过无数个 GET 和 POST 请求,或者已经看…

【Leetcode】 131. 分割回文串

给你一个字符串 s,请你将 s 分割成一些子串,使每个子串都是 回文串 。返回 s 所有可能的分割方案。 回文串 是正着读和反着读都一样的字符串。 示例 1: 输入:s "aab" 输出:[["a","a"…

java Spring Boot 手动启动热部署

好 接下来 我们讲一个对开发非常重要的东西 热部署 因为 我们在开发过程中总会希望快点看到效果 或者 你的企业项目一般很大很复杂,重启是一件非常麻烦的事 或者你在和前端同事联调,有一点小问题 你改完就要重启 前端还得等你,非常不友好 那…

docker基础命令

目录 一、安装docker 1、查看是否已安装docker 2、如果系统中已经存在旧的Docker 3、配置Docker的yum库 4、安装成功后,执行命令,配置Docker的yum源 5、安装Docker 6、启动和校验 7、配置镜像加速器,阿里云镜像加速为例 7.1、在首页的…

minikube如何设置阿里云镜像以及如何解决dashboard无法打开的解决方案_已设置图床

minikube如何设置阿里云镜像以及如何解决dashboard无法打开的解决方案 minikube dashboard报错 considerconsider-Dell-G15-5511:~$ minikube dashboard 🤔 正在验证 dashboard 运行情况 ... 🚀 正在启动代理... 🤔 正在验证 proxy 运行…

RDP协议流程详解(一)Connection Initiation阶段

Connetction Initiation是RDP连接的第一个阶段,具体包含两个消息RDP Negotiation Request和RDP Negotiation Response,下面结合协议数据包详细分析。 (1)RDP Negotiation Request 从数据包可以清晰看到此时的协议栈依次是TCP-TPKT…

swift加载h5页面空白

swift加载h5页面空白 problem 背景 xcode swift 项目,WebView方式加载h5页面本地h5地址是:http://localhost:5173/ 浏览器打开正常 Swift 加载h5: 百度官网 加载正常本地h5页面 加载空白,没有报错 override func viewDidLoad…

应力分析概要

1.概述 应力分析是一种用于结构件寿命分析的方法,最早的应用场景可能是路桥,因为西方提前我们两百年进入大工业时代。许多人工建筑的寿命是有限的,这类实际需求催生出寿命预测和诊断。结构件的失效,最根本的因素是因为应力的作用…

2023(2024届)计算机保研经验分享,圆梦山东大学

前言: Hello大家好,我是Dream,好久不见啦!在这不见的半年多时间里我一直在全身心的投入保研之中,在写下这份面经时,真的是感慨颇多,思绪万千。站在这个时间点上,回首过去的几个月&am…

postgresql-物化视图

postgresql-物化视图 物化视图创建物化视图刷新物化视图修改物化视图删除物化视图 物化视图 创建物化视图 postgresql使用create materialized view 语句创建视图 create materialized view if not exists name as query [with [NO] data];-- 创建一个包含员工统计信息的物化…

ROS导航——环境感知(激光雷达)

下载相关驱动包(激光雷达厂商应该会给出) 编译后可能会出现部分错误,以下是部分情况: (1) 移植功能包后出现c文件无法找到头文件的情况:解决链接 修改代码:(以我的雷达为…

C++项目:【高并发内存池】

文章目录 一、项目介绍 二、什么是内存池 1.池化技术 2.内存池 3.内存池主要解决的问题 4.malloc 三、定长的内存池 四、高并发内存池整体框架设计 1.高并发内存池--thread cache 1.1申请内存: 1.2释放内存: 1.3用TLS实现thread cache无锁访…

【JavaEE】JavaScript webAPI的基本知识

JavaScript Web API 文章目录 JavaScript Web APIwebAPI背景DOMDOM树 获取元素querySelectorquerySelectorAll 事件初识键盘事件onkeydownonkeypressonkeyup 操作元素获取/修改元素内容1.innerText2.innerHTML 获取/修改元素属性获取/修改表单元素属性获取/修改样式属性行内样式…