JAVA做的简单图书管理系统

合集下载

基于Java Web的图书管理系统的设计与实现

基于Java Web的图书管理系统的设计与实现

基于Java Web的图书管理系统的设计与实现随着信息技术的迅猛发展,图书管理系统在图书馆、图书商店等场所的应用越来越广泛。

基于Java Web的图书管理系统具有跨平台、易于维护和扩展等优势,已成为目前图书管理系统开发的主要技术选择。

本文将详细介绍基于Java Web的图书管理系统的设计与实现。

一、系统需求分析在进行图书管理系统的设计与实现之前,首先需要进行系统需求分析。

根据实际应用场景,我们将图书管理系统的主要功能模块分为以下几个方面:1. 图书管理:包括图书的录入、查询、修改和删除等功能。

管理员可以通过系统录入图书信息,并对图书信息进行增删改查操作,同时可以根据图书的分类、作者、出版社等条件进行高级查询。

2. 借阅管理:包括借书和还书的功能。

用户可以通过系统进行图书借阅,并在图书归还时办理还书手续。

在借阅过程中,系统需要实现图书的可借数量管理、借阅记录的生成以及逾期处理等功能。

3. 用户管理:包括用户的注册、登录和个人信息管理等功能。

用户可以通过系统注册账号,并使用账号进行登录和个人信息的管理,如修改密码、查看借阅记录等。

4. 权限管理:包括管理员和普通用户两种角色的权限管理。

管理员具有对系统的所有功能模块进行管理的权限,而普通用户只能进行图书查询和借阅等操作。

二、系统设计与实现经过系统需求分析,接下来将开始进行系统设计与实现。

1. 技术选型基于Java Web的图书管理系统,我们选择使用以下技术进行设计与实现:- 后端开发框架:Spring MVC- 前端UI框架:Bootstrap- 数据库:MySQL- 数据库访问框架:MyBatis- 前端页面交互:JavaScript、jQuery2. 数据库设计在实现图书管理系统之前,我们需要设计数据库表来存储图书信息、用户信息、借阅记录等数据。

下面是数据库表的设计:- 图书表(book):包含图书的编号、名称、作者、出版社、分类等字段。

- 用户表(user):包含用户的编号、账号、密码等字段。

基于Java的图书管理系统的设计与实现

基于Java的图书管理系统的设计与实现

基于Java的图书管理系统的设计与实现一、引言图书管理系统是一个用于管理图书信息的软件系统,它可以帮助图书馆或书店高效地管理图书的借阅、归还、查询等操作。

本文将介绍基于Java语言开发的图书管理系统的设计与实现过程,包括系统架构设计、功能模块划分、技术选型等方面。

二、系统架构设计1. 概述图书管理系统主要包括前台用户界面、后台管理界面和数据库三个部分。

前台用户界面用于读者进行图书查询、借阅等操作,后台管理界面用于管理员对图书信息进行管理,数据库用于存储图书信息。

2. 架构设计采用MVC(Model-View-Controller)架构模式,将系统分为模型层、视图层和控制层。

模型层负责数据的存取操作,视图层负责展示数据给用户,控制层负责接收用户输入并调用相应的模型进行处理。

三、功能模块划分1. 用户模块用户注册:读者可以通过注册账号来使用系统。

用户登录:已注册用户可以通过账号密码登录系统。

用户信息管理:用户可以查看和修改个人信息。

2. 图书管理模块图书查询:用户可以根据关键字搜索图书信息。

图书借阅:用户可以借阅所需图书。

图书归还:用户可以归还已借阅的图书。

3. 管理员模块管理员登录:管理员通过账号密码登录后台管理系统。

图书添加:管理员可以添加新的图书信息。

图书删除:管理员可以删除不需要的图书信息。

四、技术选型1. 后端技术Java语言:作为主要开发语言,具有跨平台性和稳定性。

Spring框架:提供了依赖注入和面向切面编程等功能。

MyBatis框架:用于数据库操作,提供了方便的ORM映射功能。

2. 前端技术HTML/CSS/JavaScript:用于前端页面的布局和交互效果。

Bootstrap框架:提供了响应式布局和丰富的UI组件。

3. 数据库MySQL数据库:作为数据存储介质,支持高并发和事务处理。

五、系统实现步骤搭建开发环境:安装JDK、Eclipse/IntelliJ IDEA等开发工具。

创建项目结构:按照MVC架构设计创建相应的包和类。

基于 java 的图书馆管理系统

基于 java 的图书馆管理系统

目录1 引言 (1)1.1课程设计选题 (1)1.2课程设计的目的 (1)1.3本选题的设计背景 (1)2 需求分析 (1)2.1 功能需求 (1)2.2 系统的开发运行环境 (2)3.1 系统体系结构设计 (2)3.2系统功能模块及主要类设计 (3)3.3数据库设计 (5)3 详细设计与实现 (7)4.1 登录模块 (7)4.2 程序主界面模块 (9)4.3 数据库连接模块 (10)4.4 数据结果集处理模块 (12)4 小结和展望 (14)参考文献 (14)附录 (15)1引言1.1课程设计选题1、《图书馆管理系统(c/s)》。

2、图书基本信息包括条码号、图书ISBN号、索书号、书名、作者、出版社和简介。

此外还包括图书类型表。

3、读者基本信息包括条码号、读者编号、姓名、性别、出生日期、图书借阅次数、期刊借阅次数。

此外还包括读者类型表。

4、图书流通信息包括图书借阅、图书归还、图书征订、图书罚款、图书清单。

5、设计一个软件能够实现这些信息的录入修改;可以完成图书查询;使用表格控件JTable来显示图书信息。

1.2课程设计的目的使学生巩固和加深以Java 语言为基础的面向对象编程技术理论知识的理解,提高实际动手编程能力的培养,掌握以Java为核心的应用软件开发方案,达到能独立阅读、编制和调试一定规模的Java程序的水平。

1.3本选题的设计背景1、图书馆作为一种信息资源集散地,图书和用户借阅资料繁多,包含很多信息数据的管理。

2、图书馆管理系统是图书馆的重要组成部分。

2需求分析2.1 功能需求1、从系统功能上主要分为三大部分:读者管理、图书管理、流通管理。

(1)用户端需要完成以下功能:①查询图书②预约图书③挂失图书④图书征订(2)管理员端需要完成以下功能:①学生用户管理:实现对学生用户信息的增、删、改、查。

②图书管理:包括图书的增、删、改等。

③管理员管理:操作者包括超级管理员和普通管理员,超级管理员可对任意管理员进行增、删、改、查,而普通管理员只有修改自己密码的权限。

javaswing图书管理系统实报告

javaswing图书管理系统实报告

四、实验方法和步骤
实验方法:
1、本系统是基于Java Swing+MySQL实现的图书管理系统。

2、采用Java Swing作为UI界面
3、MySQL数据库作为存储
4、JDBC原生方法操作
(封装了公共的增删改查方法,见src.model.access.Connect.java)
5、采用MVC模式分为Model层、View层、Controller层
6、采用了MD5进行密码加密
实验步骤:
1、需求分析
2、概念结构,绘制E-R图
3、逻辑结构设计:将E-R图转化为等价的关系模式
4、物理结构设计:数据库表的基本结构
5、功能实现
五、实验结果(截图)
1、登录界面
2、普通用户登录界面
3、管理员登录界面
4用户界面功能分别是
图书查询借阅、借阅归还信息、个人信息管理4.1借阅
4.3查询
4.4借阅信息
4.5归还
4.6个人信息管理4.7修改个人信息
4.8修改密码
5.登录界面功能5.1注册功能
6.忘记密码功能
7.管理端功能
图书信息管理、图书种类管理、读者类型管理、图书借阅信息、超级用户7.1界面
7.2添加图书
7.3删除图书
7.4修改图书
7.5图书类型管理7.6读者信息管理历史借阅信息
7.7超级管理员界面修改个人信息
修改个人密码
7.8超级管理员验证查询管理员信息
新增管理员
删除管理员
修改该管理员信息。

Java图书管理系统设计报告

Java图书管理系统设计报告

Java图书管理系统设计报告简介Java图书管理系统是一款用于管理图书馆借阅业务的应用程序。

该系统旨在简化图书馆的图书借阅和归还流程,提高图书馆的运作效率。

本文将对Java图书管理系统的设计进行详细介绍。

功能需求Java图书管理系统需要满足以下功能需求: 1. 用户注册和登录:用户可以注册新账号并通过账号密码登录系统。

2. 图书查询和展示:用户可以通过关键词搜索图书,并查看图书的详细信息和可借数量。

3. 图书借阅和归还:用户可以借阅图书,系统将相应图书的可借数量减少;用户还书时,系统将相应图书的可借数量增加。

4. 图书推荐:系统可以根据用户的借阅记录和兴趣,推荐适合用户的图书。

5. 借阅历史查询:用户可以查看自己的借阅历史记录。

系统设计数据库设计系统需要设计以下表格来存储数据: - 用户表(User):存储用户的账号、密码、姓名等信息。

- 图书表(Book):存储图书的信息,包括图书名称、作者、数量等。

- 借阅表(Borrow):存储用户的借阅记录,包括用户ID、图书ID、借阅日期等信息。

系统架构Java图书管理系统采用分层架构,包括以下几个层次: 1. 表现层(Presentation Layer):负责与用户进行交互,接收用户的输入和显示系统的输出。

2. 业务逻辑层(Business Logic Layer):处理具体的业务逻辑,例如用户登录、图书管理、借阅归还等。

3. 数据访问层(Data Access Layer):负责与数据库进行交互,包括插入、查询和更新数据的操作。

类设计系统设计需要定义以下几个类: 1. User类:表示用户,包括用户的账号、密码、姓名等属性。

2. Book类:表示图书,包括图书的名称、作者、数量等属性。

3. Borrow类:表示借阅记录,包括用户ID、图书ID、借阅日期等属性。

4. UserService类:处理与用户相关的逻辑,例如用户注册、登录等。

java实训报告--图书管理系统

java实训报告--图书管理系统

java实训报告--图书管理系统一、项目介绍本项目是一个基于Java的图书管理系统,主要包括图书类别管理、图书信息管理、读者信息管理以及借阅和归还管理等模块。

实现了对图书馆资源的有效管理,提高了图书馆工作效率,满足了读者的需求。

二、需求分析1.用户权限分级实现用户登陆验证,分为管理员和普通用户两类,管理员有图书信息、读者信息、借阅还书和系统管理四种权限,普通用户只有查询和借还书的权限。

2.图书管理管理员可以对图书进行分类管理、添加书目、查看书目、修改和删除图书信息等操作。

3.读者管理管理员可以对读者进行添加、查看、修改和删除读者信息等操作。

普通用户只能查询自己的借书信息和还书日期。

4.借阅还书管理管理员可以对图书的借阅还书进行处理和管理,包括借书和还书操作,超期处理以及还书日期提醒等。

5.系统管理管理员可以对图书馆系统进行管理,包括用户管理、修改密码等操作。

三、设计实现1.数据库设计采用MySQL数据库进行数据存储,主要包括用户表、图书分类表、图书信息表、读者信息表、借阅信息表等。

2.界面设计采用Swing框架实现界面设计,UI界面简洁美观,与用户交互友好。

3.代码实现代码主要采用Java语言实现,采用MVC模式,将业务和UI 进行分离,提高了灵活性和可维护性。

四、实现效果本系统实现了对图书馆资源的有效管理,对管理员可以方便地进行操作,对普通用户可以快速方便地查询和借阅图书。

五、总结通过该项目的实现,使我深入学习了Java语言的面向对象编程、MVC模式、MySQL数据库的使用、Swing界面设计等技术,并深刻体会到了软件开发的需求分析、系统设计、编码实现、测试等基本流程。

同时,也感受到了信息化技术在实际工作中所带来的效率和便捷。

图书馆管理系统(JavaWeb)

图书馆管理系统(JavaWeb)

图书馆管理系统(JavaWeb)图书馆管理系统(Java Web)概述基于Spring + Spring MVC + MyBatis的图书馆管理系统,使⽤Maven进⾏包管理。

主要功能包括:图书查询、图书管理、图书编辑、读者管理、图书的借阅与归还以及借还⽇志记录等。

项⽬演⽰<——点击跳转<——点击跳转<——点击跳转<——点击跳转环境配置需要提前配置好Maven环境,数据库为MySql,在src/main/resources/db.properties中修改MySql⽤户名和密码。

数据库脚本在library.sql中,可⾃动建库。

使⽤mvn jetty:run可快速搭建。

特别注意:如果要搭⼊服务器中使⽤,⽤tomcat跑需要将项⽬打包⼊tomcat中的root⽂件夹使⽤,因为项⽬设计时,⽤的jetty,所有jsp⽂件路径写的都是相对路径。

概念设计⽤户分为两类:读者、图书馆管理员。

图书馆管理员可以修改读者信息,修改书⽬信息,查看所有借还⽇志等;读者仅可以修改个⼈信息、借阅或归还书籍和查看⾃⼰的借还⽇志。

数据库E-R图逻辑设计共有6个表:1. 图书书⽬表book_info名类型长度⼩数点NULL⽤途键book_id bigint200否图书号✔name varchar200否书名author varchar150否作者publish varchar200否出版社ISBN varchar150否标准书号introduction text00是简介language varchar40否语⾔price decimal102否价格pub_date date00否出版时间class_id int110是分类号number int110是剩余数量2. 数据库管理员表admin名类型长度⼩数点NULL⽤途键admin_id bigint200否账号✔password varchar150否密码username varchar150是⽤户名3. 图书分类表class_info名类型长度⼩数点NULL⽤途键class_id int110否类别号✔class_name varchar150否类别名4. 借阅信息表lend_list名类型长度⼩数点NULL⽤途键ser_num bigint200否流⽔号✔book_id bigint200否图书号reader_id bigint200否读者证号lend_date date00是借出⽇期back_date date00是归还⽇期5. 借阅卡信息表reader_card名类型长度⼩数点NULL⽤途键reader_id bigint200否读者证号✔password varchar150否密码username varchar150是⽤户名6. 读者信息表reader_info名类型长度⼩数点NULL⽤途键reader_id bigint200否读者证号✔name varchar100否姓名sex varchar20否性别birth date00否⽣⽇address varchar500否地址phone varchar150否电话功能展⽰1. ⾸页登陆管理者账号:123456/123456(见数据库admin表)读者账号:10000/123456()见数据库reader_card表2. 管理员系统⽤登陆进⼊2.1 图书管理2.2 图书详情2.3 读者管理2.4 借还管理3. 读者系统3.1 查看全部图书3.2 个⼈信息查看,可以修个个⼈信息3.3 个⼈借阅情况查看。

javase综合案例

javase综合案例

javase综合案例综合案例:图书管理系统一、引言图书管理系统是一种用于管理与存储图书信息的软件系统。

该系统可以实现对图书的借阅、归还、续借、借阅记录查询等功能,方便图书馆管理人员进行图书管理工作。

本文将介绍一个基于JavaSE的图书管理系统的设计与实现。

二、需求分析1. 系统应具备管理员和读者两种角色,管理员可以进行图书管理操作,读者可以进行借阅和归还操作。

2. 系统应提供图书的添加、删除、修改和查询功能,管理员可通过图书的书名、作者等信息快速检索图书。

3. 系统应提供读者的注册、注销和查询功能,读者可以通过借阅号和密码登录系统。

4. 系统应记录借阅记录,包括借阅日期、归还日期和借阅状态等信息。

5. 系统应提供图书的借阅、归还和续借功能,借阅时应检查图书库存和读者的借书上限。

6. 系统应提供借阅记录的查询功能,管理员可按照读者或图书进行查询。

7. 系统应具备良好的用户界面,方便操作和使用。

三、系统设计根据需求分析,系统的核心功能包括图书管理、读者管理和借阅管理。

因此,可以设计三个核心类:Book、Reader和BorrowRecord。

1. Book类Book类用于存储图书信息,包括书名、作者、出版社、出版日期、图书编号和库存数量等属性。

该类还提供图书的添加、删除和修改方法,以及根据书名、作者等信息进行查询的方法。

2. Reader类Reader类用于存储读者信息,包括借阅号、姓名、性别、年龄和借书上限等属性。

该类还提供读者的注册、注销和查询方法,以及读者登录系统的方法。

3. BorrowRecord类BorrowRecord类用于存储借阅记录,包括借阅日期、归还日期、借阅状态、借阅图书和借阅读者等属性。

该类还提供借书、还书和续借的方法,以及查询借阅记录的方法。

四、系统实现根据系统设计,可以编写相关的Java类文件来实现图书管理系统。

以下是部分代码示例:Book.java:```javapublic class Book {private String name;private String author;private String publisher;private String publicationDate;private int stock;// 构造方法// 添加图书public void addBook() {// 添加图书逻辑}// 删除图书public void deleteBook() {// 删除图书逻辑}// 修改图书public void modifyBook() {// 修改图书逻辑}// 根据书名和作者查询图书public void searchBook(String name, String author) { // 查询图书逻辑}}Reader.java:```javapublic class Reader {private String name;private String gender;private int age;private int borrowLimit;// 构造方法// 注册读者public void register() {// 注册逻辑}// 注销读者public void cancel() {// 注销逻辑}// 查询读者信息public void searchReader() {// 查询读者逻辑}// 读者登录public void login(String borrowId, String password) { // 登录逻辑}}BorrowRecord.java:```javapublic class BorrowRecord {private Date borrowDate;private Date returnDate;private boolean borrowStatus;private Book book;private Reader reader;// 构造方法// 借书public void borrow(Book book, Reader reader) {// 借书逻辑}// 还书public void returnBook(Book book, Reader reader) { // 还书逻辑}// 续借public void renew(Book book, Reader reader) {// 续借逻辑}// 查询借阅记录public void searchRecord(Book book, Reader reader) { // 查询记录逻辑}}```以上仅为图书管理系统的基本功能和类的设计示例,实际开发中还需进一步完善和优化。

java实现图书馆管理系统

java实现图书馆管理系统

java实现图书馆管理系统本⽂实例为⼤家分享了java实现图书馆管理系统的具体代码,供⼤家参考,具体内容如下思路:所有包都在book_manage包⾥利⽤⾯向对象的多态特性去除了很多if-else的判断,不同的⼦类在⽗类所对应的⽅法不同。

1.⾸先建⽴⼀个book包包⾥⾯有2个类,⼀个是Book,这个类⾥⾯包含⼀本书的全部信息另外⼀个类是BookList,这个类是⽤来管理每⼀个书,通过这个类来寻找每⼀本书。

private Book[] books = new Book[100];Book数组⾥⾯存放所有的书。

2.再建⽴⼀个包Operation 这个类⾥⾯有⼀个OI接⼝,通过对接⼝⾥⾯的Work⽅法重写,来实现管理员⾝份和普通⽤户⾝份的不同操作。

3.最后建⽴⼀个User包,⾥⾯有三个类,User,Admin,NormalUserAdmin和NormalUser都继承⾃User.User⾥秒你有⼀个数组protected IO[] operation;这个数组⾥⾯包含了⽤户或者管理员所具备的操作。

通过对数组的索引来确定具体需要调⽤的操作⽅法。

下⾯来看看代码吧:book包Book类package book_manager.book;public class Book {private String name;private String id;private String author;private int price;private String type;private boolean isBorrow;public Book(String name, String id, String author, int price,String type, boolean isBorrow) { = name;this.id = id;this.author = author;this.price = price;this.type = type;this.isBorrow = isBorrow;}@Override //Object中内置的类,⽤来格式化打印book的信息public String toString() {return "Book{" +"name='" + name + '\'' +", id='" + id + '\'' +", author='" + author + '\'' +", price=" + price +", type='" + type + '\'' +", isBorrow=" + isBorrow +'}';}public String getName(){return name;}public boolean isBorrow(){public void setBorrow(boolean bool){this.isBorrow=bool;}public String getId(){return id;}}BookList类package book_manager.book;import java.util.Arrays;public class BookList {private Book[] books = new Book[100];private int size;public BookList(){books[0] = new Book("⾦瓶梅","001", "兰陵笑笑⽣", 100,"古典名著", false);books[1] = new Book("⽔浒传","002", "施耐庵", 100,"古典名著", false);books[2] = new Book("西游记","003", "吴承恩", 100,"古典名著", false);size = 3;}public int getSize(){return size;}public void setBooks(int index,Book book){ books[index]=book;}public void setSize(int size){this.size=size;}public Book getBook(int index){return books[index];}}Operation包:ADD类package book_manager.Operation;import book_manager.book.*;import java.util.Scanner;public class ADD implements IO{@Overridepublic void work(BookList bookList) {Scanner scanner = new Scanner(System.in); System.out.println("请输⼊书名");String name =scanner.next();System.out.println("请输⼊序号");String id = scanner.next();System.out.println("请输⼊作者");String author =scanner.next();System.out.println("请输⼊价格");int price = scanner.nextInt();System.out.println("请输⼊类型");String type = scanner.next();bookList.setBooks(bookList.getSize(),book);bookList.setSize(bookList.getSize()+1);System.out.println("添加成功");}}Borrow类package book_manager.Operation;import book_manager.book.Book;import book_manager.book.BookList;import java.util.Scanner;public class Borrow implements IO{@Overridepublic void work(BookList bookList) {int i=0;int flag=0;Scanner scan = new Scanner(System.in);System.out.println("请输⼊需要借阅的书名");String name = scan.next();for(;i<bookList.getSize();i++){if(name.equals(bookList.getBook(i).getName())){if(bookList.getBook(i).isBorrow()==false){System.out.println("借阅成功");flag=1;bookList.getBook(i).setBorrow(true);}}}if(flag==0){System.out.println("不好意思,借阅失败");}}}Delete类package book_manager.Operation;import book_manager.book.BookList;import java.util.Scanner;public class Delete implements IO{public void work(BookList bookList){Scanner scanner = new Scanner(System.in);System.out.println("请输⼊想要删除的编号");String id = scanner.next();for(int i=0;i<bookList.getSize();i++){if(bookList.getBook(i).getId().equals(id)){bookList.setBooks(i,bookList.getBook(bookList.getSize())); bookList.setSize(bookList.getSize()-1);System.out.println("删除成功");}else{System.out.println("删除失败");}}}}Exit类package book_manager.Operation;import book_manager.book.BookList;public class Exit implements IO{public void work(BookList bookList) {System.out.println("退出成功");System.exit(0);}}Find类package book_manager.Operation;import book_manager.book.BookList;import java.util.Scanner;public class Find implements IO{@Overridepublic void work(BookList bookList) {int i=0;int count=0;Scanner scan = new Scanner(System.in);System.out.println("请输⼊需要查找的书名");String name = scan.next();for(;i<bookList.getSize();i++){if(name.equals(bookList.getBook(i).getName())){ count++;}}if(count==0){System.out.println("不好意思,没有找到"); }else{System.out.println("找到了,共计"+count+"本"); }}}IO接⼝package book_manager.Operation;import book_manager.book.BookList;public interface IO {abstract public void work(BookList bookList);}PrintAll类package book_manager.Operation;import book_manager.book.BookList;public class PrintAll implements IO{@Overridepublic void work(BookList bookList) {for(int i=0;i<bookList.getSize();i++){System.out.println(bookList.getBook(i));}}}Return类package book_manager.Operation;import book_manager.book.BookList;import java.util.Scanner;public class Return implements IO{@Overridepublic void work(BookList bookList) {int i=0;Scanner scan = new Scanner(System.in);System.out.println("请输⼊需要归还的ID");String id = scan.next();for(;i<bookList.getSize();i++){if(id.equals(bookList.getBook(i).getId())){if(bookList.getBook(i).isBorrow()==true){System.out.println("归还成功");bookList.getBook(i).setBorrow(false);flag=1;}else{System.out.println("归还失败");}}}if(flag==0){System.out.println("不好意思,没有此书");}}}user包:User类package book_er;import book_manager.Operation.*;import book_manager.Operation.IO;import book_manager.book.BookList;abstract public class User {String name;protected IO[] operation;public User(String name){=name;}abstract public int menu();//该⽅法被重写public void doOperation(int choice, BookList bookList) { operation[choice].work(bookList);}}Admin类package book_er;import book_manager.Operation.*;import java.util.Scanner;public class Admin extends User{public Admin(String name){super(name);operation=new IO[]{new Exit(),new Find(),new ADD(),new Delete(),new PrintAll(),};}public int menu() {System.out.println("============");System.out.println("hello " + name);System.out.println("1. 查找书籍");System.out.println("4. 打印所有信息");System.out.println("0. 退出");System.out.println("============");System.out.println("请输⼊您的选择: ");Scanner scanner = new Scanner(System.in);int choice = scanner.nextInt();return choice;}}NormalUserpackage book_er;import book_manager.Operation.*;import java.util.Scanner;public class NormalUser extends User{public NormalUser(String name){super(name);operation=new IO[]{new Exit(),new Find(),new Borrow(),new Return(),new PrintAll()};}public int menu() {System.out.println("============");System.out.println("hello " + name);System.out.println("1. 查找图书");System.out.println("2. 借阅图书");System.out.println("3. 归还图书");System.out.println("4. 查看全部书籍");System.out.println("0. 退出");System.out.println("============");System.out.println("请输⼊您的选择: ");Scanner scanner = new Scanner(System.in);int choice = scanner.nextInt();// close 本质上是在关闭 System.in// 由于后⾯还需要⽤到 System.in, 此处不能盲⽬关闭. // scanner.close();return choice;}}最后还有⼀个Test类,⾥⾯放了main函数package book_manager;import book_manager.book.BookList;import book_er.Admin;import book_er.NormalUser;import book_er;import java.util.Scanner;public class Test {public static void main(String[] args) {BookList list = new BookList();User user = login();//通过不同的choice和⾝份调⽤不同的Operation⽅法 while(true){int choice = user.menu();user.doOperation(choice, list);}}public static User login(){Scanner scanner = new Scanner(System.in);System.out.println("请输⼊你的姓名");System.out.println("请输⼊你的⾝份");System.out.println("1.普通⽤户 2.管理员");int role= scanner.nextInt();if(role==1){return new NormalUser(name);}else{return new Admin(name);}}}更多学习资料请关注专题《》。

图书管理系统源码(java实现)

图书管理系统源码(java实现)

【图书管理系统】【MainPro包】1.系统登录页面public class Login extends Frame {private static final long serialVersionUID = -1758475247807861408L;TextField text_user;TextField text_pass;public Login() {1 this.setTitle("登录");this.setLayout(null);//默认流式布局this.setSize(260, 170);/* 定义标签与文本框*/Label lbUser = new Label("用户名:");text_user = new TextField();Label lbPass = new Label("密码:");text_pass = new TextField();Button btn_ok = new Button("确定");Button btn_cancel = new Button("取消");lbUser.setBounds(40, 53, 60, 20);//x,y,width,heightlbPass.setBounds(40, 83, 60, 20);text_user.setBounds(100, 50, 120, 20);text_pass.setBounds(100, 80, 120, 20);btn_ok.setBounds(45, 120, 80, 25); // 确定按钮btn_cancel.setBounds(135, 120, 80, 25); // 取消按钮/* 添加标签与文本框*/add(lbUser);add(lbPass);add(text_user);add(text_pass);add(btn_ok);add(btn_cancel);setLocationRelativeTo(null); // 使窗体在屏幕上居中放置this.setVisible(true); // 使窗体可见btn_ok.addActionListener((new ActionListener() {public void actionPerformed(ActionEvent e) {btn_okActionPerformed(e);//自定义确定按钮触发的实施过程}}));btn_cancel.addActionListener((new ActionListener() {public void actionPerformed(ActionEvent e) {DbOp.Close(); // 关闭数据库System.exit(0);}}));this.addWindowListener(new WindowAdapter() {/* 关闭窗口*/// 重写windowClosing()方法public void windowClosing(WindowEvent e) {DbOp.Close(); // 关闭数据库System.exit(0);} }); }public void btn_okActionPerformed(ActionEvent e) {String user = text_user.getText();String pass = text_pass.getText();String is_admin;// 如果用户名或密码任一为空,则终止后续操作if (user.equals("")||pass.equals("")) {JOptionPane.showMessageDialog(null, "用户名或密码不能为空!");return;}try {// 核对用户名和密码String sql = "select * from user where username=" + "'" + user + "' and password=" + "'" + pass + "'";ResultSet rs = DbOp.executeQuery(sql);// 如果此用户存在,则记录其状态(否:不是管理员,是:是管理员)if (rs.next()) {is_admin = rs.getString("is_admin");} else {JOptionPane.showMessageDialog(null, "用户名或密码不正确!");return;}GlobalVar.login_user = user; // 记录登录的用户名ShowMain show = new ShowMain(); // 调用主程序// 只有管理员才能使用"基础管理"和"借阅管理"菜单show.setRights(is_admin);// 释放窗体及其全部组件的屏幕资源,即使释放登录窗体dispose(); // 释放当前窗体} catch (SQLException e1) {JOptionPane.showMessageDialog(null, "用户数据库有误!");}}}2.系统首页页面public class ShowMain extends Frame {private static final long serialVersionUID = 5003296786441785470L;MenuBar menuBar;Menu jcwh, jcwh_book, jcwh_reader;//基础维护:图书维护、读者维护Menu jywh, cxgl, xtgl;//借阅维护、查询管理、系统管理MenuItemjcwh_book_add,jcwh_book_update,jcwh_book_delete,jcwh_reader_add,jcwh_reader_update,jcwh_reader_delete;MenuItem jywh_borrow, jywh_back;MenuItem cxgl_book, cxgl_reader;MenuItem xtgl_update_pass, xtgl_exit;public void setRights(String rights) {// 如果不是管理员,则禁止用户维护图书信息和读者信息以及禁止进行借阅管理,即只能查询if (rights.equals("否")) {jywh.setEnabled(false);jcwh.setEnabled(false);}}public ShowMain() {setTitle("图书管理系统");setLayout(new BorderLayout());setSize(640, 480);menuBar = new MenuBar();jcwh = new Menu("基础维护");// 基础维护菜单jcwh_book = new Menu("图书维护");// 图书维护菜单jcwh_book_add = new MenuItem("添加");// 添加图书菜单jcwh_book_update = new MenuItem("修改");// 修改图书菜单jcwh_book_delete = new MenuItem("删除");// 删除图书菜单jcwh_reader = new Menu("读者维护");// 读者维护菜单jcwh_reader_add = new MenuItem("添加读者");// 添加读者菜单jcwh_reader_update = new MenuItem("修改读者");jcwh_reader_delete = new MenuItem("删除读者");jywh = new Menu("借阅管理");jywh_borrow = new MenuItem("借书管理");jywh_back = new MenuItem("还书管理");cxgl = new Menu("查询管理");cxgl_book = new MenuItem("图书查询");cxgl_reader = new MenuItem("读者查询");xtgl = new Menu("系统管理");xtgl_update_pass = new MenuItem("修改密码");xtgl_exit = new MenuItem("退出系统");// 添加图书菜单jcwh_book.add(jcwh_book_add);jcwh_book.add(jcwh_book_update);jcwh_book.add(jcwh_book_delete);jcwh.add(jcwh_book);jcwh_reader.add(jcwh_reader_add);jcwh_reader.add(jcwh_reader_update);jcwh_reader.add(jcwh_reader_delete);jcwh.add(jcwh_reader);jywh.add(jywh_borrow);jywh.add(jywh_back);cxgl.add(cxgl_book);cxgl.add(cxgl_reader);xtgl.add(xtgl_update_pass);xtgl.add(xtgl_exit);menuBar.add(jcwh);menuBar.add(jywh);menuBar.add(cxgl);menuBar.add(xtgl);setMenuBar(menuBar);setLocationRelativeTo(null); // 使窗体在屏幕上居中放置setVisible(true); // 使窗体可见jcwh_book_add.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new BookManeger("save");} });jcwh_book_update.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new BookManeger("update");} });jcwh_book_delete.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new BookManeger("delete");} });jcwh_reader_add.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new ReaderManeger("save");} });jcwh_reader_update.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new ReaderManeger("update");} });jcwh_reader_delete.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new ReaderManeger("delete");} });jywh_borrow.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new Borrow();} });jywh_back.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new Back();} });cxgl_book.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new BookQuery();} });cxgl_reader.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new ReaderQuery();} });xtgl_update_pass.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {new UpdatePassword();} });xtgl_exit.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {DbOp.Close(); // 关闭数据库System.exit(0);}});this.addWindowListener(new WindowAdapter() {/* 关闭窗口*/// 重写windowClosing()方法public void windowClosing(WindowEvent e) {DbOp.Close(); // 关闭数据库System.exit(0);}});}}3.图书管理public class BookManeger extends JFrame {private static final long serialVersionUID = 377287301994613384L;private Label lbbookid_c = new Label("图书编号");private TextField tf_bookid_c = new TextField();private Label lbbookid = new Label("图书编号");private TextField tf_bookid = new TextField();private Label lbbookname = new Label("图书名称");private TextField tf_bookname = new TextField();private Label lbbooktype = new Label("图书类别");private Choice tf_booktype = new Choice();private Label lbauthor = new Label("作者");private TextField tf_author = new TextField();private Label lbtranslator = new Label("译者");private TextField tf_translator = new TextField();private Label lbpublisher = new Label("出版社");private TextField tf_publisher = new TextField();private Label lbpublish_time = new Label("出版时间");private TextField tf_publish_time = new TextField();private Label lbprice = new Label("定价");private TextField tf_price = new TextField();private Label lbstock = new Label("库存数量");private TextField tf_stock = new TextField();private Button queryBtn = new Button("查询");private Button saveBtn = new Button("保存");private Button closeBtn = new Button("关闭");private String optionStr;BookManeger(String str) {optionStr = str;ggFrame(optionStr);saveBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("bookid", tf_bookid);map.put("bookname", tf_bookname);map.put("booktype", tf_booktype);map.put("author", tf_author);map.put("translator", tf_translator);map.put("publisher", tf_publisher);map.put("publish_time", tf_publish_time);map.put("price", tf_price);map.put("stock", tf_stock);int i ;if(optionStr.equals("delete")){i = Jcwh.btn_delActionPerformed(e, map);}else{i = Jcwh.btn_saveActionPerformed(e, map,optionStr);}if (i == 1) {String showInfo = "";if(optionStr.equals("save")){showInfo = "图书添加成功!";}else if(optionStr.equals("update")){showInfo = "图书修改成功!";}else if(optionStr.equals("delete")){showInfo = "图书删除成功!";}JOptionPane.showMessageDialog(null, showInfo);// 清空全部文本框clearAllTextfield();}}});closeBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {dispose(); // 释放当前窗体}});/* 关闭窗口*/this.addWindowListener(new WindowAdapter() {public void windowClosing(WindowEvent e) { // 关闭当前窗口dispose(); // 释放当前窗体}});}private void ggFrame(String str) {setLayout(null);setSize(500, 320);lbbookid.setBounds(50, 40, 50, 20); // 图书编号tf_bookid.setBounds(110, 40, 100, 20);lbbookname.setBounds(240, 40, 50, 20); // 图书名称tf_bookname.setBounds(300, 40, 100, 20);lbbooktype.setBounds(50, 80, 50, 20); // 图书类别tf_booktype.setBounds(110, 80, 100, 20);tf_booktype.add("科技");tf_booktype.add("文学");tf_booktype.add("社科");tf_booktype.add("其他");lbauthor.setBounds(240, 80, 50, 20); // 作者tf_author.setBounds(300, 80, 100, 20);lbtranslator.setBounds(50, 120, 50, 20); // 设置译者tf_translator.setBounds(110, 120, 100, 20);lbpublisher.setBounds(240, 120, 50, 20); // 出版社tf_publisher.setBounds(300, 120, 100, 20);lbpublish_time.setBounds(50, 160, 50, 20); // 出版时间tf_publish_time.setBounds(110, 160, 100, 20);lbprice.setBounds(240, 160, 50, 20); // 定价tf_price.setBounds(300, 160, 100, 20);lbstock.setBounds(50, 200, 50, 20); // 库存数量tf_stock.setBounds(110, 200, 100, 20);saveBtn.setBounds(150, 240, 80, 25); // 保存按钮closeBtn.setBounds(280, 240, 80, 25);// 关闭按钮if(str.equals("save")){setTitle("添加图书");}else if(str.equals("update")){setTitle("修改图书");lbbookid_c.setBounds(100, 10, 50, 20); // 图书编号tf_bookid_c.setBounds(160, 10, 100, 20);tf_bookid.setEditable(false);//修改的图书信息中id不可以修改queryBtn.setBounds(280, 10, 80, 20); // 查询按钮add(lbbookid_c);add(tf_bookid_c);add(queryBtn);queryBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("bookid", tf_bookid_c);Book book = (Book)Jcwh.btn_queryActionPerformed(e,map).get("book");if(book!=null){tf_bookid.setText(book.getId());tf_bookname.setText(book.getBookname());// 将Choice的选定项设置为其名称等于指定字符串的项tf_booktype.select(book.getBooktype());tf_author.setText(book.getAuthor());tf_translator.setText(book.getTranslator());tf_publisher.setText(book.getPublisher());tf_publish_time.setText(book.getPublish_time().toString());tf_price.setText(String.valueOf(book.getPrice()));tf_stock.setText(String.valueOf(book.getStock()));}}});saveBtn.setLabel("修改");//将按钮显示文字修改成“修改”}else if(str.equals("delete")){setTitle("删除图书");lbbookid_c.setBounds(100, 10, 50, 20); // 图书编号tf_bookid_c.setBounds(160, 10, 100, 20);tf_bookid.setEditable(false);//修改的图书信息中id不可以修改queryBtn.setBounds(280, 10, 80, 20); // 查询按钮add(lbbookid_c);add(tf_bookid_c);add(queryBtn);queryBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("bookid", tf_bookid_c);Book book = (Book)Jcwh.btn_queryActionPerformed(e,map).get("book");if(book!=null){tf_bookid.setText(book.getId());tf_bookname.setText(book.getBookname());// 将Choice的选定项设置为其名称等于指定字符串的项tf_booktype.select(book.getBooktype());tf_author.setText(book.getAuthor());tf_translator.setText(book.getTranslator());tf_publisher.setText(book.getPublisher());tf_publish_time.setText(book.getPublish_time().toString());tf_price.setText(String.valueOf(book.getPrice()));tf_stock.setText(String.valueOf(book.getStock()));}}});saveBtn.setLabel("删除");//将按钮显示文字修改成“删除”}add(lbbookid);add(tf_bookid);add(lbbookname);add(tf_bookname);add(lbbooktype);add(tf_booktype);add(lbauthor);add(tf_author);add(lbtranslator);add(tf_translator);add(lbpublisher);add(tf_publisher);add(lbpublish_time);add(tf_publish_time);add(lbprice);add(tf_price);add(lbstock);add(tf_stock);add(saveBtn);add(closeBtn);setLocationRelativeTo(null); // 使窗体在屏幕上居中放置setVisible(true); // 使窗体可见}private void clearAllTextfield() {tf_bookid.setText("");tf_bookname.setText("");tf_author.setText("");tf_translator.setText("");tf_publisher.setText("");tf_publish_time.setText("");tf_price.setText("");tf_stock.setText("");}}4.读者管理public class ReaderManeger extends JFrame {private static final long serialVersionUID = -2399939451497711745L;Label lbreaderid_c = new Label("读者编号");TextField tf_readerid_c = new TextField();Label lbreaderid = new Label("读者编号");TextField tf_readerid = new TextField();Label lbreadername = new Label("读者姓名");TextField tf_readername = new TextField();Label lbreadertype = new Label("读者类别");Choice tf_readertype = new Choice();Label lbsex = new Label("性别");Choice tf_sex = new Choice();Label lbmax_num = new Label("可借数量");TextField tf_max_num = new TextField();Label lbdays_num = new Label("可借天数");TextField tf_days_num = new TextField();Button queryBtn = new Button("查询");Button saveBtn = new Button("保存");Button closeBtn = new Button("关闭");private String optionStr;//保存、修改、删除ReaderManeger(String str){optionStr = str;ggFrame(optionStr);saveBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("readerid", tf_readerid);map.put("readername", tf_readername);map.put("readertype", tf_readertype);map.put("sex", tf_sex);map.put("days_num", tf_days_num);map.put("max_num", tf_max_num);int i ;if(optionStr.equals("delete")){i = Jcwh.btn_delReaderActionPerformed(e, map);}else{i = Jcwh.btn_saveReaderActionPerformed(e,map,optionStr);}if (i == 1) {String showInfo = "";if(optionStr.equals("save")){showInfo = "读者添加成功!";}else if(optionStr.equals("update")){showInfo = "读者修改成功!";}else if(optionStr.equals("delete")){showInfo = "读者删除成功!";}JOptionPane.showMessageDialog(null, showInfo);// 清空全部文本框clearAllTextfield();}}});closeBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {dispose(); // 释放当前窗体}});this.addWindowListener(new WindowAdapter() {public void windowClosing(WindowEvent e) { // 关闭当前窗口dispose(); // 释放当前窗体}});}private void ggFrame(String str) {setLayout(null);setTitle("添加读者信息");setSize(500, 230);lbreaderid.setBounds(50, 50, 50, 20);tf_readerid.setBounds(110, 50, 100, 20);lbreadername.setBounds(240, 50, 50, 20);tf_readername.setBounds(300, 50, 100, 20);lbreadertype.setBounds(50, 80, 50, 20);tf_readertype.setBounds(110, 80, 100, 20);tf_readertype.add("教师");tf_readertype.add("学生");tf_readertype.add("职工");lbsex.setBounds(240, 80, 50, 20);tf_sex.setBounds(300, 80, 100, 20);tf_sex.add("男");tf_sex.add("女");lbmax_num.setBounds(50, 110, 50, 20);tf_max_num.setBounds(110, 110, 100, 20);lbdays_num.setBounds(240, 110, 50, 20);tf_days_num.setBounds(300, 110, 100, 20);saveBtn.setBounds(150, 150, 80, 25);closeBtn.setBounds(280, 150, 80, 25);if(str.equals("save")){setTitle("添加读者");}else if(str.equals("update")){setTitle("修改读者");lbreaderid_c.setBounds(100, 10, 50, 20);tf_readerid_c.setBounds(160, 10, 100, 20);tf_readerid.setEditable(false);queryBtn.setBounds(280, 10, 80, 20);add(lbreaderid_c);add(tf_readerid_c);add(queryBtn);queryBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("readerid", tf_readerid_c);Reader reader = (Reader)Jcwh.btn_queryReaderActionPerformed(e,map).get("reader");if(reader!=null){tf_readerid.setText(reader.getId());tf_readername.setText(reader.getReadername());tf_readertype.select(reader.getReadertype());tf_sex.select(reader.getSex());tf_days_num.setText(String.valueOf(reader.getDays_num()));tf_max_num.setText(String.valueOf(reader.getMax_num()));}}});saveBtn.setLabel("修改");//将按钮显示文字修改成“修改”}else if(str.equals("delete")){setTitle("删除图书");lbreaderid_c.setBounds(100, 10, 50, 20);tf_readerid_c.setBounds(160, 10, 100, 20);tf_readerid.setEditable(false);queryBtn.setBounds(280, 10, 80, 20);add(lbreaderid_c);add(tf_readerid_c);add(queryBtn);queryBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) {HashMap<String, Object> map = new HashMap<String, Object>();map.put("readerid", tf_readerid_c);Reader reader = (Reader)Jcwh.btn_queryReaderActionPerformed(e,map).get("reader");if(reader!=null){tf_readerid.setText(reader.getId());tf_readername.setText(reader.getReadername());tf_readertype.select(reader.getReadertype());tf_sex.select(reader.getSex());tf_days_num.setText(String.valueOf(reader.getDays_num()));tf_max_num.setText(String.valueOf(reader.getMax_num()));}}});saveBtn.setLabel("删除");//将按钮显示文字修改成“删除”}add(lbreaderid);add(lbreadername);add(lbreadertype);add(lbsex);add(lbmax_num);add(lbdays_num);add(tf_readerid);add(tf_readername);add(tf_max_num);add(tf_days_num);add(tf_readertype);add(tf_sex);add(saveBtn);add(closeBtn);setLocationRelativeTo(null);setVisible(true);}private void clearAllTextfield() {tf_readerid.setText("");tf_readername.setText("");tf_max_num.setText("");tf_days_num.setText("");}public static void main(String[] args) {ReaderManeger r = new ReaderManeger("update");}}5.借书public class Borrow extends Frame {private static final long serialVersionUID = -1036076990599464079L;String SepLine = "-------------------------------------------------";Label lbbookid = new Label("图书编号");Label lbreaderid = new Label("读者编号");TextField tf_bookid = new TextField();TextField tf_readerid = new TextField();Button queryBtn = new Button("查询");Label lbbookinfo = new Label(SepLine + "图书信息" + SepLine); Label lbbookname = new Label("图书名称:");Label tf_bookname = new Label("xx");Label lbauthor = new Label("作者:");Label tf_author = new Label("xx");Label lbpublisher = new Label("出版社:");Label tf_publisher = new Label("xx");Label lbpublish_time = new Label("出版时间:");Label tf_publish_time = new Label("xx");Label lbprice = new Label("定价:");Label tf_price = new Label("xx");Label lbstock = new Label("库存数量:");Label tf_stock = new Label("xx");Label lbreaderinfo = new Label(SepLine + "读者信息" + SepLine); Label lbreadername = new Label("读者姓名:");Label tf_readername = new Label("xx");Label lbreadertype = new Label("读者类型:");Label tf_readertype = new Label("xx");Label lbmax_num = new Label("最大可借数:");Label tf_max_num = new Label("xx");Label lbdays_num = new Label("最大可借天数:");Label tf_days_num = new Label("xx");Label lbborrowinfo = new Label(SepLine + "借阅信息" + SepLine); Label lbborrowednum = new Label("该读者已借图书数量:"); Label tf_borrowednum = new Label("xx");Label lbif_borrow = new Label("该读者是否可借所选图书:"); Label tf_if_borrow = new Label("xx");Label lbborrow_date = new Label("借阅日期:");Label tf_borrow_date = new Label("xx");Button borrowBtn = new Button("借出");Button closeBtn = new Button("关闭");public Borrow() {setLayout(null);setTitle("借阅图书");setSize(500, 420);this.setForeground(Color.BLACK); // 设置前景色为黑色lbbookid.setBounds(30, 40, 50, 25); // 图书编号tf_bookid.setBounds(90, 40, 90, 20);lbreaderid.setBounds(200, 40, 50, 25); // 读者编号tf_readerid.setBounds(260, 40, 90, 20);queryBtn.setBounds(370, 40, 80, 25); // 查询按钮lbbookinfo.setBounds(30, 70, 440, 25); // 图书信息提示条lbbookname.setBounds(30, 100, 60, 25); // 图书名称tf_bookname.setBounds(90, 100, 200, 25);lbauthor.setBounds(310, 100, 60, 25); // 作者tf_author.setBounds(370, 100, 90, 25);lbpublisher.setBounds(30, 125, 60, 25); // 出版社tf_publisher.setBounds(90, 125, 200, 25);lbpublish_time.setBounds(310, 125, 60, 25); // 出版时间tf_publish_time.setBounds(370, 125, 90, 25);lbprice.setBounds(30, 150, 60, 25); // 定价tf_price.setBounds(90, 150, 200, 25);lbstock.setBounds(310, 150, 60, 25); // 库存数量tf_stock.setBounds(370, 150, 90, 25);lbreaderinfo.setBounds(30, 180, 440, 25); // 读者信息提示条lbreadername.setBounds(30, 205, 60, 25); // 读者姓名tf_readername.setBounds(90, 205, 90, 25);lbreadertype.setBounds(310, 205, 60, 25); // 读者类型tf_readertype.setBounds(370, 205, 90, 25);lbmax_num.setBounds(30, 230, 75, 25); // 最大可借数tf_max_num.setBounds(105, 230, 90, 25);lbdays_num.setBounds(310, 230, 85, 25); // 最大可借天数tf_days_num.setBounds(395, 230, 70, 25);lbborrowinfo.setBounds(30, 260, 440, 25); // 借阅信息提示条lbborrowednum.setBounds(30, 285, 120, 25);// 已借图书数量tf_borrowednum.setBounds(150, 285, 50, 25);lbif_borrow.setBounds(30, 310, 145, 25); // 是否可借tf_if_borrow.setBounds(175, 310, 50, 25);lbborrow_date.setBounds(30, 335, 60, 25);// 借书日期tf_borrow_date.setBounds(90, 335, 100, 25);borrowBtn.setBounds(160, 365, 80, 25);// 借出按钮borrowBtn.setEnabled(false); // 开始时禁用借出按钮closeBtn.setBounds(260, 365, 80, 25);// 关闭按钮queryBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) { btn_querywActionPerformed(e); } }); borrowBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) { btn_borrowActionPerformed(e); } });closeBtn.addActionListener(new ActionListener() {public void actionPerformed(ActionEvent e) { setForeground(Color.BLACK); dispose(); } }); this.addWindowListener(new WindowAdapter() {public void windowClosing(WindowEvent e) {setForeground(Color.BLACK); // 设置前景色为黑色dispose(); // 关闭窗体}});add(lbbookid);add(lbreaderid);add(queryBtn);add(lbbookinfo);add(lbbookname);add(lbauthor);add(lbpublisher);add(lbpublish_time);add(lbprice);add(lbstock);add(lbreaderinfo);add(lbreadername);add(lbreadertype);add(lbmax_num);add(lbdays_num);add(lbborrowinfo);add(lbborrowednum);add(lbif_borrow);add(lbborrow_date);add(borrowBtn);add(closeBtn);setLocationRelativeTo(null); // 使窗体在屏幕上居中放置setVisible(true); // 使窗体可见setForeground(Color.RED); // 设置前景色为红色add(tf_bookid);add(tf_readerid);add(tf_bookname);add(tf_author);add(tf_publisher);add(tf_publish_time);add(tf_price);add(tf_stock);add(tf_readername);add(tf_readertype);add(tf_max_num);add(tf_days_num);add(tf_borrowednum);add(tf_if_borrow);add(tf_borrow_date);}// 图书和读者查询private void btn_querywActionPerformed(ActionEvent e) {String bookid = tf_bookid.getText();String readerid = tf_readerid.getText();// 如果图书编号或读者编号两者均为空,或者有一个为空,则返回if (bookid.equals("") || readerid.equals("")) {JOptionPane.showMessageDialog(null, "图书编号和读者编号均不能为空!");init(); // 重新初始化各参数并禁止借出按钮return;}// 按编号查询图书,结果存入book对象中Book book = BookSelect.SelectBookById(bookid);if (book != null) { // 如果查询到结果,将其显示在各文本框中tf_bookname.setText(book.getBookname());tf_author.setText(book.getAuthor());tf_publisher.setText(book.getPublisher());tf_publish_time.setText(book.getPublish_time().toString());tf_price.setText(String.valueOf((book.getPrice())));tf_stock.setText(String.valueOf(book.getStock()));} else {JOptionPane.showMessageDialog(null, "图书编号有误,查无此书!");init(); // 重新初始化各参数并禁止借出按钮return;}if (book.getStock() == 0) {JOptionPane.showMessageDialog(null, "图书已无库存,无法借阅!");init(); // 重新初始化各参数并禁止借出按钮return;}// 按编号查询读者,结果存入reader对象中Reader reader = ReaderSelect.selectReaderById(readerid);// 如果查询到结果,将其显示在各文本框中if (reader != null) {tf_readername.setText(reader.getReadername());tf_readertype.setText(reader.getReadertype());tf_max_num.setText(String.valueOf(reader.getMax_num()));tf_days_num.setText(String.valueOf(reader.getDays_num()));} else {JOptionPane.showMessageDialog(null, "读者编号有误,查无此人!");init(); // 重新初始化各参数并禁止借出按钮return;}// 查询指定读者是否已借过指定图书且未归还if (IfBorrowBack.findbook(bookid, readerid)) {JOptionPane.showMessageDialog(null, "该读者已借阅所选图书,且未归还!");init(); // 重新初始化各参数并禁止借出按钮return;}// 统计读者所借图书数量int borrowednum = statborrowednum(readerid);tf_borrowednum.setText(String.valueOf(borrowednum));// 如果读者已借图书尚未超出其允许最大借书量,则允许其继续借阅所选图书if (borrowednum < reader.getMax_num()) {tf_if_borrow.setText("是");// 创建一个简单日期格式对象,注意:MM一定要用大写SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");// 创建日期变量,其内容为当前日期Date currentdate = new Date();// 将日期按指定格式输出String borrowdate = sdf.format(currentdate);tf_borrow_date.setText(borrowdate);borrowBtn.setEnabled(true); // 使借出按钮有效} else {JOptionPane.showMessageDialog(null, "该读者借书过多,无法继续借阅!");init(); // 重新初始化各参数并禁止借出按钮return;}}// 填写借出图书记录private void btn_borrowActionPerformed(ActionEvent e) {String sql;String bookid = tf_bookid.getText();String readerid = tf_readerid.getText();String borrowdate = tf_borrow_date.getText();// 为borrow表增加借书记录sql = "insert into borrow (book_id,reader_id,"+ "borrow_date,if_back) values('" + bookid + "','" + readerid + "','" + borrowdate + "','否')";。

Java实验报告之图书管理系统

Java实验报告之图书管理系统

Java实验报告图书管理系统1.管理员界面<<密码验证<<展示所有图书<<查找图书<<添加书籍<<删除书籍<<修改密码<<返回上一层<<结束2.学生界面<<身份识别<<查找图书<<借阅图书<<归还书籍<<返回上一层<<结束3.退出程序源代码:Main.javapackage pany;import java.util.Date;import java.util.Scanner;public class Main {public static void main(String[] args) {// write your code hereUser U;Library L=new Library("东北大学图书馆");System.out.println("欢迎来到东北大学图书馆");Book b1=new Book("java编程思想","sdhf","554532",new Date(2016,12,13),15);Book b2=new Book("C++编程","nimei","15654",newDate(2017,5,13),5);Students s1=new Undergraduate("黎明","20175821"); Students s2=new Master("狭隘","20164545");b1.BookUser.add(s2);b1.BookUser.add(s1);b2.BookUser.add(s2);b2.BookUser.add(s1);L.addBook(b1);L.addBook(b2);//在以上的代码中都是为了增加图书馆中的藏书Scanner sc=new Scanner(System.in);String order;//命令操作板while(true){System.out.println("命令操作符\n<<AccessADInterface\n<<AccessSTInterface\n<<over");System.out.print("<<");order=sc.next();if(order.equals("AccessADInterface")){Administrators A=new Administrators();if (A.getPassWord() == 1){while(true) {System.out.println("命令操作符\n<<ShowAllBook\n<<SearchBook\n<<AddBook\n<<DeleteBook\n<< ChangePassWord\n<<GoBack\n<<over");System.out.print("<<");order = sc.next();if (order.equals("ShowAllBook")) {L.ShowBook();} else if(order .equals( "SearchBook")) {L.ShowBook(L.SearchBook());} else if(order.equals( "AddBook") ){L.addBook();} else if(order .equals( "DeleteBook")) {L.DeleteBook();} elseif(order.equals("ChangePassWord")){A.changePassWord();} else if (order .equals( "GoBack")) {break;} else if (order .equals( "over")) { System.out.println("已退出图书管理系统");System.exit(0);}}}else{System.exit(0);}} else if(order.equals("AccessSTInterface")){ U=erComing();while (true){System.out.println("<<SearchBook\n<<BorrowBook\n<<ReturnBo ok\n<<GoBack\n<<over");System.out.print("<<");order=sc.next();if(order.equals("SearchBook")) {L.ShowBook(L.SearchBook());}else if(order.equals("BorrowBook")){ L.SearchBook().BookBorrow(U);}else if(order.equals("ReturnBook")){ L.ReturnBook(U);}else if(order.equals("GoBack")){break;}}}else if(order.equals("over")){System.out.println("已退出图书管理系统"); System.exit(0);}else {System.out.println("输入了错误的指令");continue;}}}}Library.javapackage pany;import java.util.Scanner;import java.util.Vector;public class Library {public static final int OK=1;public static final int ERROR=1;Vector<Object> book= new Vector();//用来存储书类丹书类中也存有用户类private String Libraryname;Scanner sc=new Scanner(System.in);Library (String name){this.Libraryname=name;}public User UserComing() {int kind;User U;Scanner sc = new Scanner(System.in);System.out.println("如果你是老师请输入1,若是学生请输入2");while (true) {while(true){kind = sc.nextInt();if (kind == 1) {U = new Teacher();return U;} else if (kind == 2) {System.out.println("如果你是本科生请输入1,若是硕士研究生请输入2");while (true){kind=sc.nextInt();if(kind==1){U = new Undergraduate();return U;}else if(kind==2){U=new Master();return U;}else{System.out.println("输入错误");break;}}} else {System.out.println("输入错误");System.out.println("请重新输入:");break;}}}}public void addBook(Book b){book.add(b);}public void addBook(){int i;i=1;Book b;while(i==1){b=new Book();this.addBook(b);System.out.println("如果要继续输入书本信息就输入1,否则就输入2");i=sc.nextInt();}}public Book SearchBook(){String BookName;Book b;System.out.println("请输入你要借查询的书"); BookName=sc.next();for(int i=0;i<this.book.size();i++){b=(Book)this.book.elementAt(i);if(b.bookName.equals(BookName)){return b;}}return null;}public void ReturnBook(User U){User u;Book b;b=this.SearchBook();for(int i=0;i<b.BookUser.size();i++){u=(User) b.BookUser.elementAt(i);if(u==U){U.numBookBor--;b.BookUser.remove(i);b.surplus++;System.out.println("还书成功");return;}else {System.out.println("您不是这本书的借阅者,不能还书");return;}}System.out.println("找不到你要的书");}public void DeleteBook(){String BookName;Book b;System.out.println("请输入你要删除的书");BookName=sc.next();for(int i=0;i<this.book.size();i++){b=(Book)this.book.elementAt(i);if(b.bookName.equals(BookName)){if(b.BookUser.size()==0){this.book.remove(i);System.out.println("已经成功的删除书籍");}else {System.out.println("还有人尚未还书,不能够删除书籍");}}}}public void ShowBook(){Book b;for(int i=0;i<this.book.size();i++){b=(Book)book.elementAt(i);System.out.println((i+1)+"\t"+b.bookName+"\t"+b.auther+"\t" +b.bookNum+"\t"+b.depositTime.getYear()+"\t"+b.depositTime. getMonth()+"\t"+b.depositTime.getDay()+"\t"+b.surplus);}}public void ShowBook(Book b){System.out.println("\t"+b.bookName+"\t"+b.auther+"\t"+b.boo kNum+"\t"+b.depositTime.getYear()+"\t"+b.depositTime.getMon th()+"\t"+b.depositTime.getDay()+"\t"+b.surplus);}}Book.javapackage pany;import java.util.Scanner;import java.util.Vector;public class Library {public static final int OK=1;public static final int ERROR=1;Vector<Object> book= new Vector();//用来存储书类丹书类中也存有用户类private String Libraryname;Scanner sc=new Scanner(System.in);Library (String name){this.Libraryname=name;}public User UserComing() {int kind;User U;Scanner sc = new Scanner(System.in);System.out.println("如果你是老师请输入1,若是学生请输入2");while (true) {while(true){kind = sc.nextInt();if (kind == 1) {U = new Teacher();return U;} else if (kind == 2) {System.out.println("如果你是本科生请输入1,若是硕士研究生请输入2");while (true){kind=sc.nextInt();if(kind==1){U = new Undergraduate();return U;}else if(kind==2){U=new Master();return U;}else{System.out.println("输入错误");break;}}} else {System.out.println("输入错误");System.out.println("请重新输入:");break;}}}}public void addBook(Book b){book.add(b);}public void addBook(){int i;i=1;Book b;while(i==1){b=new Book();this.addBook(b);System.out.println("如果要继续输入书本信息就输入1,否则就输入2");i=sc.nextInt();}}public Book SearchBook(){String BookName;Book b;System.out.println("请输入你要借查询的书");BookName=sc.next();for(int i=0;i<this.book.size();i++){b=(Book)this.book.elementAt(i);if(b.bookName.equals(BookName)){return b;}}return null;}public void ReturnBook(User U){User u;Book b;b=this.SearchBook();for(int i=0;i<b.BookUser.size();i++){u=(User) b.BookUser.elementAt(i);if(u==U){U.numBookBor--;b.BookUser.remove(i);b.surplus++;System.out.println("还书成功");return;}else {System.out.println("您不是这本书的借阅者,不能还书");return;}}System.out.println("找不到你要的书");}public void DeleteBook(){String BookName;Book b;System.out.println("请输入你要删除的书");BookName=sc.next();for(int i=0;i<this.book.size();i++){b=(Book)this.book.elementAt(i);if(b.bookName.equals(BookName)){if(b.BookUser.size()==0){this.book.remove(i);System.out.println("已经成功的删除书籍");}else {System.out.println("还有人尚未还书,不能够删除书籍");}}}}public void ShowBook(){Book b;for(int i=0;i<this.book.size();i++){b=(Book)book.elementAt(i);System.out.println((i+1)+"\t"+b.bookName+"\t"+b.auther+"\t" +b.bookNum+"\t"+b.depositTime.getYear()+"\t"+b.depositTime. getMonth()+"\t"+b.depositTime.getDay()+"\t"+b.surplus);}}public void ShowBook(Book b){System.out.println("\t"+b.bookName+"\t"+b.auther+"\t"+b.boo kNum+"\t"+b.depositTime.getYear()+"\t"+b.depositTime.getMon th()+"\t"+b.depositTime.getDay()+"\t"+b.surplus);}}User.javapackage pany;import java.util.Date;import java.util.Scanner;class User{public String name;public int numBookBor;//借书的数量//public Date borrowTime;public String Id;public Scanner sc=new Scanner(System.in); User(){}}class Students extends User{}//想想其实也不过如此class Undergraduate extends Students{Undergraduate(String sName,String id){=sName;this.Id=id;}Undergraduate(){System.out.println("请输入你的姓名:");=sc.next();System.out.println("请输入你的学号:");this.Id=sc.next();this.numBookBor=0;}}class Master extends Students{Master(String sName,String id){=sName;this.Id=id;}Master(){System.out.println("请输入你的姓名:");=sc.next();System.out.println("请输入你的学号:");this.Id=sc.next();this.numBookBor=0;}}class Teacher extends User{Teacher(String tName,String id){=tName;this.Id=id;}Teacher(){System.out.println("请输入你的姓名:");=sc.next();System.out.println("请输入你的工号:");this.Id=sc.next();this.numBookBor=0;}}Administrators/javapackage pany;import java.util.Scanner;public class Administrators {; private String passWod;Scanner sc=new Scanner(System.in);Administrators(){this.passWod="neu123";}public int getPassWord(){String passWord;for(int i=0;i<3;i++){System.out.println("请输入密码:");System.out.print("<<");passWord=sc.next();if( passWord.equals(this.passWod)){return 1;}else {System.out.println("密码错误,您还有"+(2-i)+"机会");}}return 0;}public void changePassWord(){String passWord;for(int i=0;i<3;i++){System.out.println("请输入原密码:\n<<");passWord=sc.next();if( passWord.equals(this.passWod)){System.out.println("请输入新密码:\n<<");this.passWod=sc.next();break;}else {System.out.println("密码错误,您还有"+(2-i)+"机会");}}}}。

图书借阅管理系统java代码

图书借阅管理系统java代码

以我给的标题写原创文档,最低1200字,要求以Markdown文本格式输出,不要带图片和AI、人工智能、Markdown、GPT等关键词,标题为:图书借阅管理系统java代码# 图书借阅管理系统Java代码## 一、介绍图书借阅管理系统是一个帮助图书馆管理图书借阅情况的系统。

本系统基于Java开发,采用面向对象的编程方式,实现了对图书信息、借阅记录等数据的管理与处理。

用户可以通过该系统查询图书信息、借阅图书、归还图书,并实现了管理员对系统的管理功能。

## 二、功能模块### 1. 图书管理模块- 实现对图书信息的添加、删除、修改和查询功能。

- 对图书的分类管理,方便用户按照分类查找图书信息。

### 2. 用户管理模块- 用户注册与登录功能,保证用户数据的安全。

- 用户查询借阅情况、借阅历史等个人信息。

### 3. 借阅管理模块- 实现图书的借阅功能,包括借书日期、归还日期等信息的记录。

- 用户借阅超时提醒,确保图书及时归还。

### 4. 管理员模块- 管理员登录后可以对图书信息、用户信息进行管理。

- 实现图书归还、逾期处理等功能。

## 三、系统架构本系统采用MVC(Model-View-Controller)架构,实现了模型层、视图层、控制层之间的分离,提高了系统的灵活性和可维护性。

具体架构如下:1. Model层:负责处理数据的逻辑操作,包括对图书信息、用户信息、借阅记录等数据的管理。

2. View层:负责系统的界面展示,包括用户界面和管理员界面。

3. Controller层:负责处理用户请求,调用Model层的方法,并将结果返回给View层进行展示。

## 四、代码示例以下是借阅图书的Java代码示例:```javapublic class BorrowBook {private Book book;private User user;private Date borrowDate;private Date returnDate;// Constructorpublic BorrowBook(Book book, User user, Date borrowDate, Date returnDate) {this.book = book;er = user;this.borrowDate = borrowDate;this.returnDate = returnDate;}// Getters and setters}```以上代码实现了一个借阅图书的类`BorrowBook`,包含了借阅的图书信息、用户信息,借阅时间和归还时间。

原创java图书馆管理系统课程设计总结

原创java图书馆管理系统课程设计总结

原创Java图书馆管理系统课程设计总结一、引言本文档总结了我在课程中设计和开发的Java图书馆管理系统的经验。

该系统旨在提供一个高效、可靠的图书馆管理平台,以帮助图书馆更好地管理其图书、借阅情况和读者信息。

二、需求分析在设计系统之前,我首先进行了需求分析。

通过与图书馆管理员的交流,我确定了以下功能需求: 1. 图书管理:包括图书的添加、删除、更新和查询功能。

2. 读者管理:包括读者的注册、删除、更新和查询功能。

3. 借阅管理:包括借书和还书的操作,以及借阅记录的查询和统计功能。

三、系统设计3.1 系统架构图书馆管理系统采用三层架构,包括表示层、业务逻辑层和数据访问层。

- 表示层:负责与用户交互、展示数据和接收用户输入。

- 业务逻辑层:包含系统的核心业务逻辑,负责处理用户请求,协调表示层和数据访问层。

- 数据访问层:负责与数据库进行交互,提供数据访问接口供业务逻辑层调用。

3.2 类设计我设计了以下几个核心类: 1. Book类:表示图书对象,包含图书的编号、名称、作者等属性。

提供了图书的CRUD操作方法。

2. Reader类:表示读者对象,包含读者的编号、姓名、联系方式等属性。

提供了读者的CRUD操作方法。

3. Borrow类:表示借阅记录对象,包含借阅记录的编号、图书编号、读者编号、借书日期、还书日期等属性。

提供了借阅记录的CRUD操作方法。

4. LibraryManager类:表示图书馆管理员对象,负责处理用户请求,包括图书和读者的管理、借阅功能等。

四、开发和测试4.1 开发环境和工具本系统使用Java语言进行开发,使用Eclipse作为开发工具,MySQL作为数据库。

4.2 开发过程在开发过程中,我按照需求分析阶段的设计思路,依据类设计,逐步实现了系统的各个功能模块。

在每个阶段,我进行了单元测试和集成测试,以确保系统的功能正确性和稳定性。

4.3 测试结果经过多轮测试,系统在不同场景下表现良好。

java图书馆管理系统实验报告

java图书馆管理系统实验报告

java图书馆管理系统实验报告Java图书馆管理系统实验报告一、引言图书馆是一个重要的知识资源中心,为读者提供各种书籍和资料,帮助他们获取知识和信息。

然而,传统的图书馆管理方式存在一些问题,如借阅过程繁琐、图书管理不便等。

为了解决这些问题,我们设计并实现了一个基于Java的图书馆管理系统。

二、系统需求分析1. 用户管理:系统需要提供用户管理功能,包括读者和管理员两种角色。

读者可以注册、登录、查询图书信息、借阅和归还图书等;管理员可以管理图书信息、读者信息、借阅记录等。

2. 图书管理:系统需要提供图书管理功能,包括图书的增加、删除、修改和查询等。

管理员可以根据图书的编号、名称、作者等信息进行查询和操作。

3. 借阅管理:系统需要提供借阅管理功能,包括读者的借阅记录、借阅期限的控制、逾期罚款等。

读者可以查询自己的借阅记录,管理员可以审核借阅申请、处理逾期情况等。

三、系统设计与实现1. 技术选型:我们选择使用Java语言进行系统的设计与实现。

Java具有跨平台性、面向对象的特点,适合用于开发图书馆管理系统这样的应用。

2. 数据库设计:我们使用MySQL数据库来存储系统的数据。

设计了读者表、图书表、借阅记录表等,并建立了相应的关系。

3. 界面设计:系统的界面采用了Java Swing技术来实现。

我们设计了用户登录界面、主界面、图书查询界面、借阅记录界面等。

4. 功能实现:根据系统需求,我们实现了用户管理、图书管理和借阅管理等功能。

通过编写相应的Java代码,实现了用户注册、登录、图书增删改查、借阅和归还等操作。

四、系统测试与评估1. 功能测试:我们对系统的各个功能进行了测试,包括用户注册、登录、图书查询、借阅和归还等。

测试结果显示系统的功能正常,能够满足用户的需求。

2. 性能评估:我们对系统的性能进行了评估,包括响应时间、并发处理能力等。

评估结果显示系统的性能良好,能够满足一般图书馆的需求。

3. 用户反馈:我们邀请了一些用户进行系统的使用,并收集了他们的反馈意见。

毕业论文 java图书管理系统

毕业论文 java图书管理系统

毕业论文 java图书管理系统毕业论文:Java图书管理系统引言:随着数字化时代的到来,图书馆管理系统也逐渐转向了电子化和自动化。

Java 作为一种广泛应用于软件开发的编程语言,具有跨平台性和易于学习的特点,因此在图书管理系统的开发中也被广泛采用。

本篇论文将探讨Java图书管理系统的设计与实现。

一、需求分析在设计图书管理系统之前,我们首先需要进行需求分析。

一般来说,图书管理系统的基本功能包括图书的录入、查询、借阅和归还等。

此外,系统还应该具备用户管理、权限控制、统计分析等功能。

通过详细的需求分析,我们可以明确系统的功能和性能要求,为后续的设计和开发奠定基础。

二、系统设计在系统设计阶段,我们需要确定系统的架构和模块划分。

通常,Java图书管理系统可以采用三层架构,即表示层、业务逻辑层和数据访问层。

表示层负责与用户的交互,展示图书信息和接收用户输入;业务逻辑层处理用户请求,并进行相应的业务逻辑处理;数据访问层负责与数据库进行交互,完成数据的读写操作。

通过合理的模块划分,可以提高系统的可维护性和可扩展性。

三、数据库设计数据库设计是图书管理系统中至关重要的一环。

在设计数据库时,我们需要确定数据库的表结构和关系。

一般来说,图书管理系统的数据库包括图书表、用户表、借阅表等。

通过合理的表结构设计和关系建立,可以实现对图书、用户和借阅信息的高效管理和查询。

四、系统实现在系统实现阶段,我们需要根据需求和设计,编写相应的代码。

Java图书管理系统可以使用Java语言和相关的开发框架进行开发。

例如,可以使用JavaFX作为图形界面的开发工具,使用Spring框架进行业务逻辑的处理,使用MyBatis框架进行数据库的访问等。

通过合理的选择和使用开发工具和框架,可以提高系统的开发效率和代码的可维护性。

五、系统测试在系统开发完成后,我们需要进行系统测试。

系统测试主要包括功能测试、性能测试和安全测试等。

功能测试用于验证系统是否满足需求,性能测试用于评估系统的性能指标,安全测试用于检测系统的安全性。

基于java的图书管理系统毕业设计

基于java的图书管理系统毕业设计

基于java的图书管理系统毕业设计一个基于Java的图书管理系统是一个较为典型的毕业设计项目。

基本有以下几个步骤:1.需求分析:首先需要明确项目的具体需求,包括图书信息的管理、借阅管理、用户权限管理等。

在此基础上,进一步分析需求,确定系统的具体功能和模块。

2.系统设计:系统设计包括系统架构设计、模块设计、数据库设计等。

在此,建议采用MVC设计模式,将系统分为模型层、视图层和控制层,实现各个模块之间的松耦合,并提高系统的可维护性和可扩展性。

3.系统实现:在系统设计完成后,进入系统实现阶段。

在此,需要选择合适的开发工具和技术,例如Java SE、JavaFX、MySQL等,根据需求和设计,逐步实现各个模块和功能。

4.测试和调试:在系统实现完成后,需要进行系统的测试和调试,包括单元测试、集成测试、系统测试等,确保系统的稳定性和可靠性。

5.文档编写和报告撰写:在系统开发完成后,需要编写系统的使用说明文档、操作手册等,并根据项目要求,编写系统设计报告和毕业论文。

在开发过程中,还需要注意以下几点:1.安全性:在设计和实现系统时,需要考虑系统的安全性,包括用户权限管理、数据安全等。

建议采用加密算法、防护措施等,确保系统的安全性。

2.用户友好性:系统应该具有良好的用户体验,操作简单易懂,功能实用,使用户能够快速上手,提高使用效率。

3.扩展性:在设计和实现系统时,需要考虑系统的扩展性,即系统应该具有一定的可拓展性,可以适应未来的需求变化和业务扩展。

4.代码规范:代码应该规范、清晰、易读,遵循Java编码规范和面向对象设计原则,提高代码质量和可维护性。

综上所述,基于Java的图书管理系统是一个较为典型的毕业设计项目,需要在需求分析、系统设计、系统实现、测试和调试、文档编写和报告撰写等方面下功夫,注重安全性、用户友好性、扩展性和代码规范,才能开发出稳定、可靠、实用的系统。

javaweb简单的图书管理系统

javaweb简单的图书管理系统

实验报告实验课程:Web应用开发学生姓名:学号:专业班级:2018年6月18日南昌大学实验报告学生姓名:学号:专业班级:实验类型:□验证■综合□设计□创新实验日期:实验成绩:一、实验项目名称《Web应用开发》综合训练二、实验目的和要求使用Java+JSP+Servlet技术,选用EL、JSTL、Struts、Hibernate、myBatis、jQuery 等技术,开发一个基本Web的应用程序,以达到掌握Web应用开发的基本原理、具备使用Java+JSP+Servlet技术结合流行框架技术开发Web应用程序的能力,从而提升学生的Web编程能力。

要求学生自选题目,开发一个模拟的Web应用程序。

可以一人一题,也可以多人一题。

但是每人必须单独完成动态Web页面10页以上。

要求学生根据需求描述独自完成需求分析,软件设计、程序模块设计以及程序的编写、调试和测试。

设计和程序完成后,要求根据指定的格式要求,独自完成设计报告的撰写。

三、实验基本情况本实训要求根据下述需求陈述写出需求分析文本并进行软件开发,并列出源代码和运行结果。

四、需求分析项目介绍这是一个简单的图书管理系统,由一个管理员来实现对用户的删除,图书的增加,修改和图书的删除功能,用户注册登录后可以实现对图书的借阅和归还。

由于时间关系在设计项目时有很多不好的地方,未来得及修改,在管理员登录界面采用了图形验证码,由于是同样的技术,在用户登录界面就没有采用图形验证技术。

功能需求1.用户注册2.图书添加3.图书修改4.用户管理5.图书借阅6.归还图书五、软件设计ER图程序流程数据库设计模块设计及运行结果项目整体采用MVC 模式,整体上运用jsp+javabean+servlet+jdbc+dao,每个jsp页面采用jQuery技术作为背景,实现简单的动态背景,部分页面运用EL、JSTL、js中的点击事件、Bootsrap、图形验证码、分页技术以及邮箱页面。

六、源代码1.用户类User.Javapackage vo;public class User {private String name,pwd;public String getName() {return name;}public void setName(String name) { = name;}public String getPwd() {return pwd;}public void setPwd(String pwd) {this.pwd = pwd;}}2.图书类bookinfo.javapackage vo;public class bookinfo{private String bno,bname,author,price,other;public String getBno() {return bno;}public void setBno(String bno) {this.bno = bno;}public String getBname() {return bname;}public void setBname(String bname) {this.bname = bname;}public String getAuthor() {return author;}public void setAuthor(String author) {this.author = author;}public String getPrice() {return price;}public void setPrice(String price) {this.price = price;}public String getOther() {return other;}public void setOther(String other) {this.other = other;}}3.借书信息类package vo;public class lendbook{private String username, bno,bname,author,price,other;public String getUsername() {return username;}public void setUsername(String username) {ername = username;}public String getBno() {return bno;}public void setBno(String bno) {this.bno = bno;}public String getBname() {return bname;}public void setBname(String bname) { this.bname = bname;}public String getAuthor() {return author;}public void setAuthor(String author) { this.author = author;}public String getPrice() {return price;}public void setPrice(String price) { this.price = price;}public String getOther() {return other;}public void setOther(String other) { this.other = other;}}4.用户功能UserDao.javapackage dao;import java.util.List;import java.sql.*;import java.util.ArrayList;import vo.bookinfo;import er;import vo.lendbook;import dbc.JdbcUtil;public class UserDao{public void add(User user) throws Exception{//添加用户Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="insert into user values(?,?)";ps=conn.prepareStatement(sql);ps.setString(1, user.getName());ps.setString(2, user.getPwd());ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public void add_book(bookinfo book) throws Exception{//添加图书Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="insert into book_info values(?,?,?,?,?)";ps=conn.prepareStatement(sql);ps.setString(1, book.getBno());ps.setString(2, book.getBname());ps.setString(3, book.getAuthor());ps.setString(4, book.getPrice());ps.setString(5, book.getOther());ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public void lend_book(lendbook book) throws Exception{//借出图书Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="insert into lendbook values(?,?,?,?,?,?)";ps=conn.prepareStatement(sql);ps.setString(1, book.getUsername());ps.setInt(2, Integer.parseInt(book.getBno()));ps.setString(3, book.getBname());ps.setString(4, book.getAuthor());ps.setString(5, book.getPrice());ps.setString(6, book.getOther());ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public List<User> QueryAll() throws Exception//列出全部用户{Connection conn=null; PreparedStatement ps=null;ResultSet rs=null;List<User> userList=new ArrayList<User>(); try{conn=JdbcUtil.getConnection();String sql="select * from user";ps=conn.prepareStatement(sql);rs=ps.executeQuery();while(rs.next()){User user=new User();user.setName(rs.getString(1));user.setPwd(rs.getString(2));userList.add(user);}}finally{JdbcUtil.free(rs, ps, conn);}return userList;}public void delete(String bookno) throws Exception//删除图书{Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="delete from book_info where bno=?";ps=conn.prepareStatement(sql);ps.setString(1, bookno);ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public void returnbook(String bno,String username) throws Exception//归还图书{Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="delete from lendbook where bno=? and username=?";ps=conn.prepareStatement(sql);ps.setString(1, bno);ps.setString(2, username);ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public void delete_user(String username) throws Exception//删除用户{Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="delete from user where name=?";ps=conn.prepareStatement(sql);ps.setString(1, username);ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}public int getPageCount() throws Exception{//分页Connection conn=null;PreparedStatement ps=null;ResultSet rs=null;int recordCount=0,t1=0,t2=0;try{conn=JdbcUtil.getConnection();String sql="select count(*) from book_info";ps=conn.prepareStatement(sql);rs=ps.executeQuery();rs.next();recordCount=rs.getInt(1);t1=recordCount%5;t2=recordCount/5;}finally{JdbcUtil.free(null, ps, conn);}return t1==0?t2:t2+1;}public List<bookinfo> QueryAll_book(int pageNo) throws Exception//列出全部图书{Connection conn=null;PreparedStatement ps=null;ResultSet rs=null;int pageSize=5;int startRecno=(pageNo-1)*pageSize;List<bookinfo> bookList=new ArrayList<bookinfo>();try{conn=JdbcUtil.getConnection();String sql="select * from book_info order by bno limit ?,?";ps=conn.prepareStatement(sql);ps.setInt(1, startRecno);ps.setInt(2, pageSize);rs=ps.executeQuery();while(rs.next()){bookinfo book=new bookinfo();book.setBno(rs.getString(1));book.setBname(rs.getString(2));book.setAuthor(rs.getString(3));book.setPrice(rs.getString(4));book.setOther(rs.getString(5));bookList.add(book);}}finally{JdbcUtil.free(rs, ps, conn);}return bookList;}public List<lendbook> QueryAll_lendbook(String username) throws Exception//列出已借图书{Connection conn=null;PreparedStatement ps=null;ResultSet rs=null;List<lendbook> bookList=new ArrayList<lendbook>();try{conn=JdbcUtil.getConnection();String sql="select * from lendbook where username=?";ps=conn.prepareStatement(sql);ps.setString(1,username );rs=ps.executeQuery();while(rs.next()){lendbook book=new lendbook();book.setUsername(rs.getString(1));book.setBno(rs.getString(2));book.setBname(rs.getString(3));book.setAuthor(rs.getString(4));book.setPrice(rs.getString(5));book.setOther(rs.getString(6));bookList.add(book);}}finally{JdbcUtil.free(rs, ps, conn);}return bookList;}public void modify_book(bookinfo book) throws Exception{//修改图书Connection conn=null;PreparedStatement ps=null;try{conn=JdbcUtil.getConnection();String sql="update book_info set bname=?,author=?,price=?,other=? where bno=?";ps=conn.prepareStatement(sql);ps.setString(1, book.getBname());ps.setString(2, book.getAuthor());ps.setString(3, book.getPrice());ps.setString(4, book.getOther());ps.setString(5, book.getBno());ps.executeUpdate();}finally{JdbcUtil.free(null, ps, conn);}}}5.获取表格值代码:function getTableContent(node) {var tr1 = node.parentNode.parentNode;var name=tr1.cells[0].innerText;window.location.href="<%=path%>/delete_user?name="+name;alert(name);}7.背景jQuery代码由于代码过长,不展示;七、运行结果1.管理员登录页面:管理员登录界面采用简单的CSS、jQuery、以及图形验证码,当图形验证码输入不正确以及账号密码输入不正确会出现相相应提示,同时点击相信的输入框,提示输入对应类型的背景字体会消失,当鼠标点击其他地方时会相应出现,采用的是placeholder属性,我们平时单纯的html的输入框以及提交的按钮,让人感觉不是很舒适,采用简单的CSS将他们的边框去除,然后加上相应的边框。

毕业论文 java图书管理系统

毕业论文 java图书管理系统

毕业论文 java图书管理系统Java图书管理系统是一种管理和维护图书信息的软件系统,其主要目的是帮助图书管理员更加便捷和高效地处理图书的各种信息和管理任务。

本文将详细介绍一个基于Java编程语言的图书管理系统的设计和实现过程,主要包括系统需求分析、系统架构设计、技术选型、系统实现和测试等方面内容。

一、系统需求分析1.系统功能需求:(1) 图书信息的添加、修改、删除和查询功能(2) 用户账户管理功能,包括用户注册、登录、修改和删除等功能(3) 图书借阅和归还功能(4) 借阅历史记录查询功能(5) 管理员管理功能,包括管理员账户注册、登录、修改和删除等功能2.系统性能需求:(1) 系统响应速度快、稳定性高,能够同时处理多个用户请求(2) 系统具有一定的容错性,能够应对突发故障的情况(3) 系统具有一定的可扩展性和可维护性,方便后期系统的维护和升级二、系统架构设计基于系统需求分析,我们采用了三层架构设计,即表现层、逻辑层和数据访问层。

其中,表现层包括用户界面等,逻辑层实现系统的业务逻辑,数据访问层则负责访问数据库中的数据。

具体架构如下所示:三、技术选型为了实现这个图书管理系统,我们采用了以下技术:1.开发环境:Eclipse IDE2.数据库:MySQL3.后端框架:SpringMVC4.前端框架:Bootstrap5.数据访问层框架:MyBatis6.其他技术:HTML、CSS、JavaScript、JSP等四、系统实现1.系统登录:2.图书管理:3.借阅管理:4.归还管理:五、系统测试我们对系统进行了多项测试,包括性能测试、稳定性测试等,结果表明我们的系统能够满足系统需求分析中的各项功能和性能需求,并且具有较高的稳定性和可靠性。

六、总结本文介绍了一个基于Java编程语言的图书管理系统的设计和实现过程,包括系统需求分析、系统架构设计、技术选型、系统实现和测试等方面内容。

本系统采用了三层架构设计,采用了多项技术,经过测试能够满足系统需求分析中的各项功能和性能需求,在实现过程中我们也遇到了一些问题,但我们通过合理的解决方案最终成功地完成了这个项目。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

package Tools;import java.sql.*;import org.junit.Test;public class ConnDB{Connection con;Statement stmt=null;ResultSet rs=null;String driverName="com.mysql.jdbc.Driver";//驱动程序名String user="root";//MySQL 配置时的用户名String password="root";//MySQL配置时的密码String url="jdbc:mysql://localhost:3306/library";//URL指向要访问的数据库地址///连接数据库public ConnDB(){try{Class.forName(driverName);//加载数据库程序con=DriverManager.getConnection(url,user,password);//使用getConnection()方法,连接MySQL数据库!!if(!con.isClosed()){System.out.println("连接成功~!");}else{System.out.println("连接失败~!");}}catch(Exception e){System.err.println(e.getMessage());}}//执行SQL查询,并返回查询结果集public ResultSet select(String sql){try{Class.forName(driverName);con=DriverManager.getConnection(url,user,password);stmt=con.createStatement();rs=stmt.executeQuery(sql);}catch(Exception e){System.err.println(e.getMessage());}return rs;}@Testpublic void testSelect(){}/*执行SQL更新,并返回影响到的记录条数*/public int update(String sql){int rs=0;try{Class.forName(driverName);con=DriverManager.getConnection(url,user,password);stmt=con.createStatement();rs=stmt.executeUpdate(sql);}catch(Exception e){System.err.println(e.getMessage());}return rs;}public void testupdate(){}public static void main(String[]args){new ConnDB();}}package Library.Management.System;import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.*;import javax.swing.text.JTextComponent;import Tools.ConnDB;public class addInterface implements ActionListener{JFrame frame;JPanel p1,p2,p3;JLabel l1,l2,l3,l4;JTextField t1,t2,t3,t4;JButton last,next,enter,cancel,delete; public addInterface(){frame=new JFrame("增加/修改");l1=new JLabel("图书编号");t1=new JTextField(10);l2=new JLabel("书本名称");t2=new JTextField(10);l3=new JLabel("定价");t3=new JTextField(10);l4=new JLabel("出版社");t4=new JTextField(10);p1=new JPanel();p1.add(l1);p1.add(t1);p1.add(l2);p1.add(t2);p2=new JPanel();p2.add(l3);p2.add(t3);p2.add(l4);p2.add(t4);p3=new JPanel();last=new JButton("上一条");next=new JButton("下一条");enter=new JButton("确认");delete=new JButton("删除");cancel=new JButton("取消");p3.add(last);p3.add(next);p3.add(enter);p3.add(cancel);p3.add(delete);enter.addActionListener(this);cancel.addActionListener(this);frame.add(BorderLayout.NORTH,p1);frame.add(BorderLayout.CENTER,p2);frame.add(BorderLayout.SOUTH,p3);frame.setVisible(true);frame.setSize(500,150);frame.setResizable(false);frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE);}/*public static void main(String[]args){new addInterface();}*/@Overridepublic void actionPerformed(ActionEvent e){//TODO Auto-generated method stubif(e.getSource()==cancel){frame.dispose();}if(e.getSource()==enter){ConnDB c=new ConnDB();String sql="insert library values('"+t1.getText()+"','"+t2.getText()+"','"+t3.getText()+"','"+t4.getText()+"')";@SuppressWarnings("unused")int rs=c.update(sql);String[]rowValues={t1.getText(),t2.getText(),t3.getText(),t4.getText()};InterfaceMain.tablemodel.addRow(rowValues);}}}package Library.Management.System;//import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import java.sql.ResultSet;import javax.swing.*;import Tools.ConnDB;public class selInterface implements ActionListener{ JFrame frame;JPanel p1,p2,p3,p4,p5,p6;JLabel l1,l2,l3;JRadioButton bh,mc,cbs;ButtonGroup g;JTextField t1,t2,t3;JButton enter,cancel;JTextArea jt;JScrollPane scrollPane;public selInterface(){frame=new JFrame("查询");bh=new JRadioButton();bh.addActionListener(this);l1=new JLabel("图书编号");t1=new JTextField(10);mc=new JRadioButton();mc.addActionListener(this);l2=new JLabel("书本名称");t2=new JTextField(10);cbs=new JRadioButton();cbs.addActionListener(this);l3=new JLabel("出版社");t3=new JTextField(10);t1.setEditable(false);t2.setEditable(false);t3.setEditable(false);g=new ButtonGroup();g.add(bh);g.add(mc);g.add(cbs);p1=new JPanel();p1.add(bh);p1.add(l1);p1.add(t1);p2=new JPanel();p2.add(mc);p2.add(l2);p2.add(t2);p3=new JPanel();p3.add(cbs);p3.add(l3);p3.add(t3);p4=new JPanel();enter=new JButton("确定");cancel=new JButton("取消");enter.addActionListener(this);cancel.addActionListener(this);p4.add(enter);p4.add(cancel);p5=new JPanel();jt=new JTextArea(10,20);jt.setEditable(false);scrollPane=new JScrollPane(jt);p5.add(scrollPane);p6=new JPanel();//p6.setLayout(new GridLayout(5,1));p6.add(p1);p6.add(p2);p6.add(p3);p6.add(p5);p6.add(p4);frame.add(p6);frame.setVisible(true);frame.setSize(350,400);frame.setResizable(false);frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); }public static void main(String[]args){new selInterface();}@Overridepublic void actionPerformed(ActionEvent e){//TODO Auto-generated method stubif(bh.isSelected()){t1.setEditable(true);t2.setEditable(false);t3.setEditable(false);}if(mc.isSelected()){t1.setEditable(false);t2.setEditable(true);t3.setEditable(false);}if(cbs.isSelected()){t1.setEditable(false);t2.setEditable(false);t3.setEditable(true);}if(e.getSource()==enter){String sql=null;ConnDB con=new ConnDB();sql="SELECT*FROM library where图书编号='"+t1.getText()+"'or书本名称='"+t2.getText()+"'or'"+t3.getText()+"'=出版社";ResultSet rs=con.select(sql);String[]tempData=new String[4];try{while(rs.next()){for(int i=0;i<4;i++){tempData[i]=rs.getString(i+1);jt.append(tempData[i]+"");}jt.append("\n");}}catch(Exception e2){//TODO:handle exception}}if(e.getSource()==cancel){frame.dispose();}}}package Library.Management.System;import java.awt.*;import java.awt.event.*;import java.sql.*;import java.util.Vector;import javax.swing.*;import javax.swing.table.DefaultTableModel;import Tools.ConnDB;public class InterfaceMain implements ActionListener{JFrame frame;JPanel p1,p2,p3;JButton add,sel,del,exit;JTable table;static DefaultTableModel tablemodel;JScrollPane scrollPane;Connection con;public InterfaceMain(){//主界面和四个按钮还有监控按钮(北部)frame=new JFrame("图书管理系统");p1=new JPanel();add=new JButton("增加");sel=new JButton("查询");del=new JButton("删除");exit=new JButton("退出");p1.add(add);p1.add(sel);p1.add(del);p1.add(exit);add.addActionListener(this);sel.addActionListener(this);del.addActionListener(this);exit.addActionListener(this);//分割线(中部)p2=new JPanel();JSeparator js=new JSeparator();js.setPreferredSize(new Dimension(1000,1));p2.add(js);//表格columnName是第一列的列名tableValues是表格内容(南部)Vector<String>columnName=new Vector<String>();columnName.add("图书编号");columnName.add("书名");columnName.add("定价");columnName.add("出版社");Vector<Vector<String>>tableValue=new Vector<Vector<String>>(); ConnDB c=new ConnDB();String sql="SELECT*FROM library";ResultSet rs=c.select(sql);try{while(rs.next()){Vector<String>row=new Vector<String>();String[]data=new String[4];for(int i=0;i<4;i++){data[i]=rs.getString(i+1);//System.out.println(data[i]);row.add(data[i]);}tableValue.add(row);}}catch(Exception e){//TODO:handle exception}tablemodel=new DefaultTableModel(tableValue,columnName); table=new JTable(tablemodel);table.addMouseListener(new MouseListener(){@Overridepublic void mouseClicked(MouseEvent e){int row=table.getSelectedRow();@SuppressWarnings("unused")Object o=tablemodel.getValueAt(row,0);}@Overridepublic void mousePressed(MouseEvent e){}@Overridepublic void mouseReleased(MouseEvent e){}@Overridepublic void mouseEntered(MouseEvent e){}@Overridepublic void mouseExited(MouseEvent e){}});scrollPane=new JScrollPane(table);p3=new JPanel();p3.add(scrollPane);//设置整体面板属性frame.add(BorderLayout.NORTH,p1);frame.add(BorderLayout.CENTER,p2);frame.add(BorderLayout.SOUTH,p3);frame.setVisible(true);frame.setSize(500,500);frame.setResizable(false);frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);}//主方法public static void main(String[]args){new InterfaceMain();}//四个按钮的时间处理@Overridepublic void actionPerformed(ActionEvent e){//TODO Auto-generated method stubif(e.getSource()==add){new addInterface();}if(e.getSource()==sel){new selInterface();}if(e.getSource()==del){int n=JOptionPane.showConfirmDialog(null,"是否删除?","注意!!!",JOptionPane.YES_NO_OPTION);System.out.println(n);if(n==0){int row=table.getSelectedRow();Object bh=tablemodel.getValueAt(row,0);ConnDB con=new ConnDB();String sql="Delete FROM library where图书编号="+bh;con.update(sql);tablemodel.removeRow(table.getSelectedRow());}else{System.out.println("取消");}}if(e.getSource()==exit){System.exit(0);}}}package Library.Management.System;import java.awt.*;import java.awt.event.ActionEvent;import java.awt.event.ActionListener;import javax.swing.*;import javax.swing.text.JTextComponent;import Tools.ConnDB;public class addInterface implements ActionListener{ JFrame frame;JPanel p1,p2,p3;JLabel l1,l2,l3,l4;JTextField t1,t2,t3,t4;JButton last,next,enter,cancel,delete;public addInterface(){frame=new JFrame("增加/修改");l1=new JLabel("图书编号");t1=new JTextField(10);l2=new JLabel("书本名称");t2=new JTextField(10);l3=new JLabel("定价");t3=new JTextField(10);l4=new JLabel("出版社");t4=new JTextField(10);p1=new JPanel();p1.add(l1);p1.add(t1);p1.add(l2);p1.add(t2);p2=new JPanel();p2.add(l3);p2.add(t3);p2.add(l4);p2.add(t4);p3=new JPanel();last=new JButton("上一条");next=new JButton("下一条");enter=new JButton("确认");delete=new JButton("删除");cancel=new JButton("取消");p3.add(last);p3.add(next);p3.add(enter);p3.add(cancel);p3.add(delete);enter.addActionListener(this);cancel.addActionListener(this);frame.add(BorderLayout.NORTH,p1);frame.add(BorderLayout.CENTER,p2);frame.add(BorderLayout.SOUTH,p3);frame.setVisible(true);frame.setSize(500,150);frame.setResizable(false);frame.setDefaultCloseOperation(JFrame.DISPOSE_ON_CLOSE); }/*public static void main(String[]args){new addInterface();}*/@Overridepublic void actionPerformed(ActionEvent e){//TODO Auto-generated method stubif(e.getSource()==cancel){frame.dispose();}if(e.getSource()==enter){ConnDB c=new ConnDB();String sql="insert library values('"+t1.getText()+"','"+t2.getText()+"','"+t3.getText()+"','"+t4.getText()+"')";@SuppressWarnings("unused")int rs=c.update(sql);String[]rowValues={t1.getText(),t2.getText(),t3.getText(),t4.getText()};InterfaceMain.tablemodel.addRow(rowValues);}}}。

相关文档
最新文档