java做的简单图书管理系统
基于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语言开发的图书管理系统的设计与实现过程,包括系统架构设计、功能模块划分、技术选型等方面。
二、系统架构设计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架构设计创建相应的包和类。
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图书管理系统需要满足以下功能需求: 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的图书管理系统,主要包括图书类别管理、图书信息管理、读者信息管理以及借阅和归还管理等模块。
实现了对图书馆资源的有效管理,提高了图书馆工作效率,满足了读者的需求。
二、需求分析1.用户权限分级实现用户登陆验证,分为管理员和普通用户两类,管理员有图书信息、读者信息、借阅还书和系统管理四种权限,普通用户只有查询和借还书的权限。
2.图书管理管理员可以对图书进行分类管理、添加书目、查看书目、修改和删除图书信息等操作。
3.读者管理管理员可以对读者进行添加、查看、修改和删除读者信息等操作。
普通用户只能查询自己的借书信息和还书日期。
4.借阅还书管理管理员可以对图书的借阅还书进行处理和管理,包括借书和还书操作,超期处理以及还书日期提醒等。
5.系统管理管理员可以对图书馆系统进行管理,包括用户管理、修改密码等操作。
三、设计实现1.数据库设计采用MySQL数据库进行数据存储,主要包括用户表、图书分类表、图书信息表、读者信息表、借阅信息表等。
2.界面设计采用Swing框架实现界面设计,UI界面简洁美观,与用户交互友好。
3.代码实现代码主要采用Java语言实现,采用MVC模式,将业务和UI 进行分离,提高了灵活性和可维护性。
四、实现效果本系统实现了对图书馆资源的有效管理,对管理员可以方便地进行操作,对普通用户可以快速方便地查询和借阅图书。
五、总结通过该项目的实现,使我深入学习了Java语言的面向对象编程、MVC模式、MySQL数据库的使用、Swing界面设计等技术,并深刻体会到了软件开发的需求分析、系统设计、编码实现、测试等基本流程。
同时,也感受到了信息化技术在实际工作中所带来的效率和便捷。
学校图书馆管理系统(java)
图书管理系统〔java〕本系统将会涉及到图书馆日常管理工作的根本常见细节,诸如新图书的入库登记,图书馆所有书籍的分类管理,图书的查询,图书的借阅、退还手续的登记,费旧图书的清理撤除等,本系统所要实现的这些功能根本上涵盖了图书馆的日常管理工作,根本能够满足校园图书馆的工作人员的管理需要。
在对本系统的具体开发过程当中,将采用Java语言进展开发,以Access实现后台数据库,本系统是完全基于图形化用户界面(GUI)的单机版本。
【关键字】信息化软件工程软件生命周期图形化用户界面AbstractThe full name of our System is: The Management Information System of Campus’s Library. At present, the computer technology is developing ever-growing, and the campus’s information construction also have pushing on, by contrast, the method of management in many university library is still by man, the library’workers must face to the large number of books, and also face to fall into the trouble. Actually, the work can be done by the computer which have a management information system. Then the heavy work will not be done by people, the library’workers can use computer to manage the books, and the everyday work will be easy.This is the goal which our system want to achieve finally.The principle of development to our system will be following with Software Engineering, we use the traditional model which be called Waterfall, and the course of development will be divided into six stage. We will develop the system in sequence.Our system contains many operations about library’s everyday work, such as Register New Books, Classify Books according to their subjects, Find Books, Dispose old books, and so on, our system can finish all of the work, and can meet the requirements of the library’sworkers.During the development of our system, we use the tool of JAVA to develop it, our system is on the basis of the Access Database.【KeyWords】Management Information System, Software Engineering, Ja目录一引论1〔一〕问题的定义1〔二〕可行性分析1〔1〕技术可行性1〔2〕经济可行性2二需求分析3数据库需求分析3〔1〕数据流图3〔2〕数据库逻辑构造设计4〔3〕数据库概念构造设计5 三系统设计6〔一〕总体设计6〔二〕详细设计6〔1〕各个模块的介绍6〔2〕流程图7〔3〕数据字典7〔4〕代码实现8四总结13五致谢14六参考文献14一引论〔一〕问题的定义首先,图书馆的管理直接关系到我们大学生如何更好的使用图书,更充分的利用现有资源学习,提高自身素质。
图书馆管理系统(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的图书管理系统的设计与实现。
二、需求分析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实现图书馆管理系统的具体代码,供⼤家参考,具体内容如下思路:所有包都在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实现)
【图书管理系统】【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实验报告图书管理系统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代码
以我给的标题写原创文档,最低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_项目开发实例_图书信息管理系统开发文档及源码
图书信息管理系统一、系统功能概述:根据图书信息管理系统的特点,可以将本系统分为2大功能模块,分别为:基础数据维护、系统数据维护。
本系统各个部分及其包括的具体功能模块如下图所示:二、数据库设计:图书信息表:图书类别表:用户信息表:三、系统源代码:Com.zhang.dao:Dao.java //数据库的连接与操作类package com.zhang.dao;import java.sql.Connection;import java.sql.Date;import java.sql.DriverManager;import java.sql.ResultSet;import java.sql.SQLException;import java.util.ArrayList;import java.util.List;import com.zhang.model.BookInfo;import com.zhang.model.BookType;import com.zhang.model.Operator;import com.zhang.model.Reader;import er;public class Dao {protected static String dbClassName ="com.microsoft.sqlserver.jdbc.SQLServerDriver";protected static String dbUrl = "jdbc:sqlserver://localhost:1433;"+ "DatabaseName=db_lib;SelectMethod=Cursor";protected static String dbUser = "sa";protected static String dbPwd = "zhangyong";protected static String second = null;private static Connection conn = null;//创建数据库连接private Dao() {try {if (conn == null) {Class.forName(dbClassName).newInstance();conn= DriverManager.getConnection(dbUrl, dbUser, dbPwd);System.out.println("数据库连接成功!");}elsereturn;} catch (Exception ee) {ee.printStackTrace();}}//执行查询private static ResultSet executeQuery(String sql) {try {if(conn==null)new Dao();returnconn.createStatement(ResultSet.TYPE_SCROLL_SENSITIVE,ResultSet.CONCUR _UPDATABLE).executeQuery(sql);} catch (SQLException e) {e.printStackTrace();return null;} finally {}}//执行更新private static int executeUpdate(String sql) {try {if(conn==null)new Dao();return conn.createStatement().executeUpdate(sql);} catch (SQLException e) {System.out.println(e.getMessage());//if(e.getMessage().equals("[Microsoft][SQLServer 2000 Driver for JDBC][SQLServer]DELETE 语句与 COLUMN REFERENCE 约束'FK_TB_BORRO_REFERENCE_TB_BOOKI' 冲突。
java图书信息管理系统
java图书信息管理系统今天将为⼤家分析⼀个基于javaweb的图书信息管理系统,采⽤当前⾮常流⾏的B/S体系结构,以JAVA作为开发技术,主要依赖SSM技术框架,mysql数据库建⽴本系统。
基于javaweb的图书信息管理系统项⽬使⽤框架为SSM(MYECLIPSE),选⽤开发⼯具为MYECLIPSE。
基于javaweb的图书信息管理系统为⼀个后台项⽬。
为了完成基于javaweb的图书信息管理系统,我们⾸先需要对该系统进⾏需求分析。
⼀个基于javaweb的图书信息管理系统应包含⽤户⾓⾊有管理员、学⽣。
为了能让⽤户顺利登陆系统完成相关操作,需要为每种登陆⾓⾊设置账户和密码字段。
总结得出基于javaweb的图书信息管理系统项⽬所有数据为:管理员(id)、学⽣(xuesheng)、图书(tushu)、公告(gonggao)基于javaweb的图书信息管理系统之管理员表字段名|类型|属性|描述id |INT(11) |PRIMARY KEY|管理员idusername |VARCHAR(255) ||账号password |VARCHAR(255) ||密码基于javaweb的图书信息管理系统之学⽣表字段名|类型|属性|描述id |INT(11) |PRIMARY KEY|学⽣idmingzi |VARCHAR(255) ||名字username |VARCHAR(255) ||账号password |VARCHAR(255) ||密码xinyong |VARCHAR(255) ||信⽤zhuangtai |VARCHAR(255) ||状态基于javaweb的图书信息管理系统之图书表字段名|类型|属性|描述id |INT(11) |PRIMARY KEY|图书idmingcheng |VARCHAR(255) ||名称shuliang |VARCHAR(255) ||数量shuoming |VARCHAR(255) ||说明shangjiashijian |VARCHAR(255) ||上架时间基于javaweb的图书信息管理系统之公告表字段名|类型|属性|描述id |INT(11) |PRIMARY KEY|公告idbiaoti |VARCHAR(255) ||标题neirong |VARCHAR(255) ||内容SET FOREIGN_KEY_CHECKS=0;-- ------------------------------ ------------------------------ Table structure for ggjyjavawebdtsxxglxt-- ----------------------------DROP TABLE IF EXISTS `t_id`;CREATE TABLE `t_id` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '管理员id',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` VARCHAR(255) DEFAULT NULL COMMENT '密码',PRIMARY KEY ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='管理员';-- ----------------------------DROP TABLE IF EXISTS `t_xuesheng`;CREATE TABLE `t_xuesheng` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '学⽣id',`mingzi` VARCHAR(255) DEFAULT NULL COMMENT '名字',`username` VARCHAR(255) DEFAULT NULL COMMENT '账号',`password` ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='学⽣';-- ----------------------------DROP TABLE IF EXISTS `t_tushu`;CREATE TABLE `t_tushu` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '图书id',`mingcheng` VARCHAR(255) DEFAULT NULL COMMENT '名称',`shuliang` VARCHAR(255) DEFAULT NULL COMMENT '数量',`shuoming` ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='图书';-- ----------------------------DROP TABLE IF EXISTS `t_gonggao`;CREATE TABLE `t_gonggao` (`id` INT(11) NOT NULL AUTO_INCREMENT COMMENT '公告id',`biaoti` VARCHAR(255) DEFAULT NULL COMMENT '标题',`neirong` VARCHAR(5000) DEFAULT NULL COMMENT '内容',PRIMARY KEY ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='公告';添加图书模块:系统中存在添加图书功能,通过点击添加图书可以跳转到该功能模块,在该功能模块中,填写对应的图书信息。
java图书馆管理系统实验报告
java图书馆管理系统实验报告Java图书馆管理系统实验报告一、引言图书馆是一个重要的知识资源中心,为读者提供各种书籍和资料,帮助他们获取知识和信息。
然而,传统的图书馆管理方式存在一些问题,如借阅过程繁琐、图书管理不便等。
为了解决这些问题,我们设计并实现了一个基于Java的图书馆管理系统。
二、系统需求分析1. 用户管理:系统需要提供用户管理功能,包括读者和管理员两种角色。
读者可以注册、登录、查询图书信息、借阅和归还图书等;管理员可以管理图书信息、读者信息、借阅记录等。
2. 图书管理:系统需要提供图书管理功能,包括图书的增加、删除、修改和查询等。
管理员可以根据图书的编号、名称、作者等信息进行查询和操作。
3. 借阅管理:系统需要提供借阅管理功能,包括读者的借阅记录、借阅期限的控制、逾期罚款等。
读者可以查询自己的借阅记录,管理员可以审核借阅申请、处理逾期情况等。
三、系统设计与实现1. 技术选型:我们选择使用Java语言进行系统的设计与实现。
Java具有跨平台性、面向对象的特点,适合用于开发图书馆管理系统这样的应用。
2. 数据库设计:我们使用MySQL数据库来存储系统的数据。
设计了读者表、图书表、借阅记录表等,并建立了相应的关系。
3. 界面设计:系统的界面采用了Java Swing技术来实现。
我们设计了用户登录界面、主界面、图书查询界面、借阅记录界面等。
4. 功能实现:根据系统需求,我们实现了用户管理、图书管理和借阅管理等功能。
通过编写相应的Java代码,实现了用户注册、登录、图书增删改查、借阅和归还等操作。
四、系统测试与评估1. 功能测试:我们对系统的各个功能进行了测试,包括用户注册、登录、图书查询、借阅和归还等。
测试结果显示系统的功能正常,能够满足用户的需求。
2. 性能评估:我们对系统的性能进行了评估,包括响应时间、并发处理能力等。
评估结果显示系统的性能良好,能够满足一般图书馆的需求。
3. 用户反馈:我们邀请了一些用户进行系统的使用,并收集了他们的反馈意见。
基于java的图书管理系统毕业设计
基于java的图书管理系统毕业设计一个基于Java的图书管理系统是一个较为典型的毕业设计项目。
基本有以下几个步骤:1.需求分析:首先需要明确项目的具体需求,包括图书信息的管理、借阅管理、用户权限管理等。
在此基础上,进一步分析需求,确定系统的具体功能和模块。
2.系统设计:系统设计包括系统架构设计、模块设计、数据库设计等。
在此,建议采用MVC设计模式,将系统分为模型层、视图层和控制层,实现各个模块之间的松耦合,并提高系统的可维护性和可扩展性。
3.系统实现:在系统设计完成后,进入系统实现阶段。
在此,需要选择合适的开发工具和技术,例如Java SE、JavaFX、MySQL等,根据需求和设计,逐步实现各个模块和功能。
4.测试和调试:在系统实现完成后,需要进行系统的测试和调试,包括单元测试、集成测试、系统测试等,确保系统的稳定性和可靠性。
5.文档编写和报告撰写:在系统开发完成后,需要编写系统的使用说明文档、操作手册等,并根据项目要求,编写系统设计报告和毕业论文。
在开发过程中,还需要注意以下几点:1.安全性:在设计和实现系统时,需要考虑系统的安全性,包括用户权限管理、数据安全等。
建议采用加密算法、防护措施等,确保系统的安全性。
2.用户友好性:系统应该具有良好的用户体验,操作简单易懂,功能实用,使用户能够快速上手,提高使用效率。
3.扩展性:在设计和实现系统时,需要考虑系统的扩展性,即系统应该具有一定的可拓展性,可以适应未来的需求变化和业务扩展。
4.代码规范:代码应该规范、清晰、易读,遵循Java编码规范和面向对象设计原则,提高代码质量和可维护性。
综上所述,基于Java的图书管理系统是一个较为典型的毕业设计项目,需要在需求分析、系统设计、系统实现、测试和调试、文档编写和报告撰写等方面下功夫,注重安全性、用户友好性、扩展性和代码规范,才能开发出稳定、可靠、实用的系统。
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的图书馆管理系统通常采用B/S架构,即浏览器(Browser)与服务器(Server)架构。
该架构下,用户通过浏览器访问系统,而后台服务器处理用户请求并返回相应结果。
系统的整体架构包括前端展示层、后端业务逻辑层和数据访问层。
1. 前端展示层前端展示层主要负责与用户进行交互,提供友好的界面和操作方式。
采用HTML、CSS和JavaScript等前端技术进行页面设计和开发,实现用户注册登录、图书检索借阅、个人信息管理等功能。
2. 后端业务逻辑层后端业务逻辑层负责处理前端传递过来的请求,进行相应的业务逻辑处理,并调用数据访问层进行数据操作。
采用Java语言编写后端业务逻辑代码,实现用户管理、图书管理、借阅管理等功能。
3. 数据访问层数据访问层负责与数据库进行交互,进行数据的读写操作。
通过JDBC或ORM框架(如MyBatis)实现Java代码与数据库之间的连接和数据操作,确保数据的安全性和一致性。
三、功能模块划分基于Java的图书馆管理系统通常包括以下功能模块:1. 用户管理模块用户注册:用户可以通过系统注册账号,并填写个人信息。
用户登录:注册用户可以通过用户名和密码登录系统。
个人信息管理:用户可以查看和修改个人信息。
2. 图书管理模块图书检索:用户可以通过关键字检索图书信息。
图书借阅:用户可以查看图书详情并进行借阅操作。
图书归还:用户可以归还已借阅的图书。
3. 借阅管理模块借阅记录查询:用户可以查询自己的借阅记录。
续借操作:用户可以对已借阅的图书进行续借操作。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 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.getV alueAt(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);}}}。