Obtenga el código fuente: ¡Descárguelo de "Recursos" en la página de inicio del blog!
Introducción al proyecto
El proyecto tiene una interfaz simple y elegante y funciones simples. Solo tiene tres tablas, lo cual es adecuado para principiantes de Java o diseño de cursos; las
funciones principales incluyen:
mapa de carrusel de página de inicio
Gestión de libros: lista de libros, estante de libros;
gestión de préstamos: búsqueda de libros , préstamo de libros, devolución de libros,
gestión de lectores: lista de lectores, adición de lectores;
Centro de usuarios: información personal, gestión de usuarios, agregar administradores;
necesidades ambientales
1. Entorno operativo: preferiblemente java jdk 1.8, estamos ejecutando en esta plataforma. Otras versiones también son teóricamente posibles.
2. Entorno IDE: se pueden utilizar IDEA, Eclipse, Myeclipse. Se recomienda IDEA
3. Entorno Tomcat: las versiones Tomcat 7.x, 8.x, 9.x están disponibles
4. Entorno de hardware: Windows 7/8/10 con más de 1 G de memoria o Mac OS
5. Proyecto Maven: Sí; compruebe si pom.xml está incluido en el directorio del código fuente; si es así, es un proyecto experto, de lo contrario, es un proyecto no experto
6. Base de datos: MySql versión 5.7;
pila de tecnología
1. Backend: springboot+jpa+mybatis+springsecurity+swagger+
2. Interfaz: html+javaex
Instrucciones de uso
1. Utilice Navicat u otras herramientas para crear una base de datos con el nombre correspondiente en mysql e importe el archivo sql del proyecto
2. Puede importar book-manager a la herramienta de desarrollo (idea/eclipse)
- idea: abra el código fuente archivo directamente en la carpeta, recuerde el directorio donde se encuentra el archivo pom
- eclipse: importación directa - seleccione un proyecto maven de importación existente
- verifique si maven está configurado correctamente, se recomienda usar la aceleración en la nube de Alibaba, por lo que el tiempo de espera es relativamente corto
3 Establezca el archivo de configuración application.yml en el proyecto Cambie la configuración de la base de datos a su propia configuración
4. Ejecute el proyecto, ingrese localhost:8080 para iniciar sesión
5. Nombre de usuario del administrador: admin Contraseña: 123
Capa de control de procesamiento de categorías de libros:
/**
* @description: 图书类别处理
*/
@Controller
@RequestMapping("/admin/ch/category")
public class CategoryController {
//注入
@Autowired
private LibraryCategoryService libraryCategoryService;
/**
* 添加 图书类目
*
* @param category 图书类目信息
* @param session 添加人
* @return url
* @author hiseico
*/
@RequestMapping(value = "/addCategory", method = RequestMethod.POST)
public String addCategory(TbCategory category, HttpSession session, Model model) {
List<TbCategory> categoryList = libraryCategoryService.getCategoryAll();
boolean is = false;
for (TbCategory tbCategory : categoryList) {
if (category.getCatname().equals(tbCategory.getCatname())) {
is = true;
break;
}
}
if (!is) {
// 添加 数据到 数据库,并 修改 父类目
libraryCategoryService.addBookCategory(category, session);
} else {
model.addAttribute("errorMsg", "类目已经存在");
return "errorMsg";
}
return "redirect:/admin/ch/loan_BookClassify.action";
}
/**
* 删除类目信息
*
* @param id
* @return
*/
@RequestMapping(value = "/delCategory", method = RequestMethod.GET)
public String delCategory(int id) {
// 通过 类目id 删除数据
libraryCategoryService.delBookCategoryById(id);
return "redirect:/admin/ch/loan_BookClassify.action";
}
/**
* 修改 类目关系
*
* @param category
* @return
*/
@RequestMapping(value = "/updateCategory", method = RequestMethod.POST)
public String updateCategory(TbCategory category) {
return "redirect:/admin/ch/loan_BookClassify.action";
}
@RequestMapping("/toUpdatePage")
@ResponseBody
public TbCategory toUpdatePage(int id) {
return libraryCategoryService.getCategoryById(id);
}
}
Capa de control de operaciones de libros:
/**
* @description: 图书操作
*/
@Controller
@RequestMapping("/admin/ch")
public class LibraryController {
//注入
@Autowired
private LibraryService libraryService;
/**
* 修改图书信息
*
* @param uploadFile 上传图片
* @param library 图书信息
* @return
*/
@RequestMapping(value = "/updateBook", method = RequestMethod.POST)
public String updateBook(MultipartFile uploadFile, TbLibrary library, HttpServletRequest request) {
try {
libraryService.updateOrSaveLibrary(uploadFile, library,request);
} catch (IOException e) {
e.printStackTrace();
}
return "redirect:/admin/ch/loan_bookList.action";
}
/**
* 添加图书
*
* @param uploadFile 上传图片
* @param library 图书信息
* @return
*/
@RequestMapping(value = "/addBook", method = RequestMethod.POST)
public String addBook(MultipartFile uploadFile, TbLibrary library, HttpSession session,HttpServletRequest request) {
ActiveAdmin activeAdmin = (ActiveAdmin) session.getAttribute("activeAdmin");
library.setManagerId(activeAdmin.getUserid());
try {
libraryService.updateOrSaveLibrary(uploadFile, library,request);
} catch (IOException e) {
e.printStackTrace();
}
return "redirect:/admin/ch/loan_bookList.action";
}
/**
* 根据 图书id 删除 图书
*
* @param id 图书id
* @return
*/
@RequestMapping("/delBookById")
public String delBook(int id) {
libraryService.delBookById(id);
return "redirect:/admin/ch/loan_bookList.action";
}
}
Procesamiento de visualización de la lista de la página principal:
/**
* @description: 前台页面列表显示处理
*/
@Controller
@RequestMapping("/user/ch")
public class UserBookController {
// 注入
@Autowired
private LibraryService libraryService;
@Autowired
private LibraryCategoryService libraryCategoryService;
@Autowired
private CommentService commentService;
@Autowired
private TbOrderMapper orderMapper;
@Autowired
private TbRecordMapper recordMapper;
@Value("${LOGIN_USER}")
private String LOGIN_USER; // 当前登录用户的 session 存储 属性名
@RequestMapping("/user_bookList")
public String toLibraryListByCid(TbLibraryQuery libraryQuery, PageCount pageCount, Model model, HttpSession session) {
if (libraryQuery == null || libraryQuery.getCateId() == null) {
libraryQuery = new TbLibraryQuery();
libraryQuery.setCateId((Integer) session.getAttribute("currentCategory"));
}
// 根据 类目 id
// 若 当前 类目 为 父类目 则获取 其 下面 的 所有子类目
// 若 当前 类目 为 子类目 则获取 其 同级 类目
List<TbCategory> categoryList = libraryCategoryService.getCategoryByCid(libraryQuery.getCateId());
// 获取当前类目信息
TbCategory currentCategory = libraryCategoryService.getCategoryById(libraryQuery.getCateId());
// 按照条件进行查询
PageCount<TblibraryExt> libraryPageCount = libraryService.findLibraryByAll(libraryQuery, pageCount);
// model 将数据设置到域中
model.addAttribute("subCategoryList", categoryList);
model.addAttribute("libraryPageCount", libraryPageCount);
// 默认
if (currentCategory == null) {
currentCategory = new TbCategory();
currentCategory.setId(0);
}
session.setAttribute("currentCategory", currentCategory.getId());
return "/user/user_bookList";
}
/**
* 通过 图书 id 查询 图书详细信息
*
* @param id
* @return
*/
@RequestMapping("/bookId")
public String toBookInfo(int id, Model model) {
BookExt bookInfo = libraryService.getBookInfoById(id);
// 将 时间戳 进行转换
Long dateSS = bookInfo.getLibrary().getCreatedate();
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd");
String formatDate = simpleDateFormat.format(new Date(dateSS * 1000));
bookInfo.setFormatDate(formatDate);
// 通过 图书id 获取 回复信息
List<CommentExt> commentExts = commentService.findCommentByBookId(id);
// 将 查询的 图书信息 设置到 域 中
model.addAttribute("bookInfo", bookInfo);
// 将 回复信息 设置到 域 汇总
model.addAttribute("commentExts", commentExts);
return "/user/bookDetail";
}
/**
* 用于 借阅 图书 操作
*
* @param session 用于 取 用户信息
* @param order 用户借阅关联信息
* @return
*/
@RequestMapping("/jieyue_book")
public String jieyueBook(HttpSession session, Model model, String oid, String kkid, TbOrder order) {
if (null != kkid) {
TbRecord tbRecord = recordMapper.selectByPrimaryKey(Integer.valueOf(kkid));
tbRecord.setReturnbook(2); //2代表挂失
recordMapper.updateByPrimaryKey(tbRecord);
model.addAttribute("successMsg", "图书挂失成功");
return "errorMsg";
}
if (null != oid) {
TbRecord tbOrder = recordMapper.selectByPrimaryKey(Integer.valueOf(oid));
// 插入数据
tbOrder.setBackdate(tbOrder.getBackdate() + 3 * 30 * 24 * 60 * 60);
recordMapper.updateByPrimaryKey(tbOrder);
model.addAttribute("successMsg", "续借三个月成功");
return "errorMsg";
}
// 获取 session 中的用户信息
ActiveUser activeUser = (ActiveUser) session.getAttribute("activeUser");
TbUser tbUser = new TbUser();
tbUser.setId(activeUser.getUserid());
order.setUserId(tbUser.getId());
// 插入数据
libraryService.jieyueBookById(order);
return "redirect:/user/ch/bookId.action?id=" + order.getBookId();
}
@RequestMapping("/commitInfo")
@ResponseBody
public String commitComment(HttpSession session, TbComment comment) {
// 获取 session 中的用户信息
ActiveUser activeUser = (ActiveUser) session.getAttribute("activeUser");
TbUser tbUser = new TbUser();
tbUser.setId(activeUser.getUserid());
comment.setUserId(tbUser.getId());
libraryService.addCommentInfo(comment);
return "ok";
}
}
Obtenga el código fuente: ¡Descárguelo de "Recursos" en la página de inicio del blog!