图书管理系统是一个典型的信息管理系统,可以用于管理和查询图书信息。本文将介绍如何用Java搭建一个图书管理系统。
一、环境搭建
1.安装Java开发环境(JDK)和开发工具(IDE),如Eclipse、IntelliJ IDEA等。
2.安装数据库管理系统,如MySQL、Oracle等。
二、数据库设计
1.创建数据库,命名为"bookmanagesystem"。
2.创建图书表book和管理员表admin,其中book表包括图书ID、名称、作者、出版社、价格、数量等字段;admin表包括管理员ID、姓名、密码、权限等字段。两个表之间可以通过book表中的管理员ID字段建立关联。
三、构建项目
1.新建Java项目,在项目中添加必要的jar包,如JDBC驱动等。
2.创建dao层和service层。dao层用于操作数据库,service层用于处理业务逻辑。
3.创建图书管理系统的MVC框架,包括视图层、控制层和业务层。其中,视图层负责显示数据和接受用户输入;控制层根据用户输入调用业务层完成相应任务;业务层是实现具体业务逻辑的核心部分。
4.实现登录模块。管理员输入用户名和密码,进行验证。验证通过后,可以进入管理系统界面;否则提示登录失败。
5.实现图书管理模块。包括图书查询、添加、删除、修改等功能。管理员根据需要对图书信息进行操作。
四、具体代码实现
1.实体类设计
创建Book类和Admin类,分别对应数据库中的book表和admin表。
public class Book {
private int bookId; //图书ID
private String bookName; //图书名称
private String author; //作者
private String press; //出版社
private double price; //价格
private int num; //数量
private int adminId; //管理员ID(用于建立关联)
//getter、setter...
}
public class Admin {
private int adminId; //管理员ID
private String adminName; //管理员姓名
private String password; //密码
private int role; //权限
//getter、setter...
}
2.DAO层实现
创建BookDao和AdminDao,分别对应对book表和admin表进行操作的接口。
public interface BookDao {
List<Book> queryAllBooks(); //查询所有图书信息
Book queryBookById(int bookId); //根据ID查询图书信息
boolean addBook(Book book); //添加图书信息
boolean deleteBook(int bookId); //根据ID删除图书信息
boolean updateBook(Book book); //更新图书信息
}
public interface AdminDao {
Admin queryAdminById(int adminId); //根据ID查询管理员信息
Admin queryAdminByNM(String adminName, String password); //根据姓名和密码查询管理员信息
}
3.Service层实现
创建BookService和AdminService,用于处理业务逻辑。
public interface BookService {
List<Book> queryAllBooks(); //查询所有图书信息
Book queryBookById(int bookId); //根据ID查询图书信息
boolean addBook(Book book); //添加图书信息
boolean deleteBook(int bookId); //根据ID删除图书信息
boolean updateBook(Book book); //更新图书信息
}
public interface AdminService {
Admin queryAdminById(int adminId); //根据ID查询管理员信息
Admin queryAdminByNM(String adminName, String password); //根据姓名和密码查询管理员信息
}
4.控制层实现
创建AdminController,用于处理用户的请求和显示响应结果。
public class AdminController {
private AdminService adminService = new AdminServiceImpl(); //创建AdminService实现类对象
//处理登录请求
public String login(HttpServletRequest request) {
String adminName = request.getParameter("adminName"); //获取登录用户名
String password = request.getParameter("password"); //获取登录密码
Admin admin = adminService.queryAdminByNM(adminName, password); //根据用户名和密码查询管理员信息
if(admin != null) {
request.getSession().setAttribute("admin", admin); //将管理员信息存入Session
return "/book/bookList.jsp"; //登录成功,跳转到图书列表页面
} else {
request.setAttribute("error", "用户名或密码错误!"); //登录失败,存储错误信息
return "/index.jsp"; //返回登录页面
}
}
//处理查询所有图书请求
public String queryAllBooks(HttpServletRequest request) {
List<Book> bookList = bookService.queryAllBooks(); //查询所有图书信息
request.setAttribute("bookList", bookList); //存储查询结果
return "/book/bookList.jsp"; //将查询结果显示到图书列表页面
}
//处理根据ID查询图书请求
public String queryBookById(HttpServletRequest request) {
int bookId = Integer.parseInt(request.getParameter("bookId")); //获取查询的图书ID
Book book = bookService.queryBookById(bookId); //根据ID查询图书信息
request.setAttribute("book", book); //存储查询结果
return "/book/bookDetail.jsp"; //将查询结果显示到图书详情页面
}
//处理添加图书请求
public String addBook(HttpServletRequest request) {
String bookName = request.getParameter("bookName");
String author = request.getParameter("author");
String press = request.getParameter("press");
double price = Double.parseDouble(request.getParameter("price"));
int num = Integer.parseInt(request.getParameter("num"));
int adminId = ((Admin)request.getSession().getAttribute("admin")).getAdminId(); //获取当前管理员ID
Book book = new Book();
book.setBookName(bookName);
book.setAuthor(author);
book.setPress(press);
book.setPrice(price);
book.setNum(num);
book.setAdminId(adminId);
bookService.addBook(book); //添加图书信息
return "/book/bookList.jsp"; //添加成功,回到图书列表页面
}
//处理删除图书请求
public String deleteBook(HttpServletRequest request) {
int bookId = Integer.parseInt(request.getParameter("bookId")); //获取要删除的图书ID
bookService.deleteBook(bookId); //删除图书信息
return "/book/bookList.jsp"; //删除成功,回到图书列表页面
}
//处理更新图书请求
public String updateBook(HttpServletRequest request) throws Exception {
int bookId = Integer.parseInt(request.getParameter("bookId"));
String bookName = request.getParameter("bookName");
String author = request.getParameter("author");
String press = request.getParameter("press");
double price = Double.parseDouble(request.getParameter("price"));
int num = Integer.parseInt(request.getParameter("num"));
Book book = bookService.queryBookById(bookId);
book.setBookName(bookName);
book.setAuthor(author);
book.setPress(press);
book.setPrice(price);
book.setNum(num);
bookService.updateBook(book); //更新图书信息
return "/book/bookList.jsp"; //更新成功,回到图书列表页面
}
}
以上是用Java搭建图书管理系统的具体步骤和代码实现。当然,该系统只是一个简单的示例,可以根据实际需求进行修改和扩展。相应教学奉上,大家可以同时学习:
【Java项目实战】手把手教你从零开始搭建图书管理系统,新手也能跟上(附源码),半小时搞定!_哔哩哔哩_bilibili