基于javaweb+mysql的springboot图书管理系统(java+html+springboot+thymeleaf+mysql+maven)

基于javaweb+mysql的springboot图书管理系统(java+html+springboot+thymeleaf+mysql+maven)

运行环境

Java≥8、MySQL≥5.7

开发工具

eclipse/idea/myeclipse/sts等均可配置运行

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb+mysql的SpringBoot图书管理系统(java+html+springboot+thymeleaf+mysql+maven)

一、项目运行 环境配置:

Jdk1.8 + Tomcat8.5 + mysql + Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)

项目技术:

HTML +Springboot+ SpringMVC + MyBatis + ThymeLeaf + JavaScript + JQuery + Ajax + maven等等。


res.put("msg", "读者登陆成功!");

} else {

res.put("stateCode", "0");

res.put("msg", "账号或密码错误!");

return res;

@RequestMapping("/admin_main.html")

public ModelAndView toAdminMain(HttpServletResponse response) {

return new ModelAndView("admin_main");

@RequestMapping("/reader_main.html")

public ModelAndView toReaderMain(HttpServletResponse response) {

return new ModelAndView("reader_main");


if (bookService.matchBook(searchWord)) {

ArrayList<Book> books = bookService.queryBook(searchWord);

ModelAndView modelAndView = new ModelAndView("admin_books");

modelAndView.addObject("books", books);

return modelAndView;

} else {

return new ModelAndView("admin_books", "error", "没有匹配的图书");

@RequestMapping("/reader_querybook_do.html")

public ModelAndView readerQueryBookDo(String searchWord) {

if (bookService.matchBook(searchWord)) {

ArrayList<Book> books = bookService.queryBook(searchWord);

ModelAndView modelAndView = new ModelAndView("reader_books");


@RequestMapping("/reader_books.html")

public ModelAndView readerBooks(HttpServletRequest request) {

ArrayList<Book> books = bookService.getAllBooks();

ReaderCard readerCard = (ReaderCard) request.getSession().getAttribute("readercard");

ArrayList<Lend> myAllLendList = lendService.myLendList(readerCard.getReaderId());

ArrayList<Long> myLendList = new ArrayList<>();

for (Lend lend : myAllLendList) {

// 是否已归还

if (lend.getBackDate() == null) {

myLendList.add(lend.getBookId());

ModelAndView modelAndView = new ModelAndView("reader_books");

modelAndView.addObject("books", books);

modelAndView.addObject("myLendList", myLendList);


if (readerId > 0 && readerCardService.addReaderCard(readerInfo, password)) {

redirectAttributes.addFlashAttribute("succ", "添加读者信息成功!");

} else {

redirectAttributes.addFlashAttribute("succ", "添加读者信息失败!");

return "redirect:/allreaders.html";

@RequestMapping("reader_info_edit.html")

public ModelAndView readerInfoEditReader(HttpServletRequest request) {

ReaderCard readerCard = (ReaderCard) request.getSession().getAttribute("readercard");

ReaderInfo readerInfo = readerInfoService.getReaderInfo(readerCard.getReaderId());

ModelAndView modelAndView = new ModelAndView("reader_info_edit");

modelAndView.addObject("readerinfo", readerInfo);

return modelAndView;


//负责处理loginCheck.html请求

//请求参数会根据参数名称默认契约自动绑定到相应方法的入参中

@RequestMapping(value = "/api/loginCheck", method = RequestMethod.POST)

public @ResponseBody

Object loginCheck(HttpServletRequest request) {

long id = Long.parseLong(request.getParameter("id"));

String passwd = request.getParameter("passwd");

boolean isReader = loginService.hasMatchReader(id, passwd);

boolean isAdmin = loginService.hasMatchAdmin(id, passwd);

HashMap<String, String> res = new HashMap<>();

if (isAdmin) {

Admin admin = new Admin();

String password = loginService.getReaderPassword(id);

if (password.equals(oldPasswd)) {

if (loginService.readerRePassword(id, newPasswd)) {

redirectAttributes.addFlashAttribute("succ", "密码修改成功!");

return "redirect:/reader_repasswd.html";

} else {

redirectAttributes.addFlashAttribute("error", "密码修改失败!");

return "redirect:/reader_repasswd.html";

} else {

redirectAttributes.addFlashAttribute("error", "旧密码错误!");

return "redirect:/reader_repasswd.html";

//配置404页面

@RequestMapping("*")


long readerId = Long.parseLong(request.getParameter("readerId"));

if (readerInfoService.deleteReaderInfo(readerId) && readerCardService.deleteReaderCard(readerId)) {

redirectAttributes.addFlashAttribute("succ", "删除成功!");

} else {

redirectAttributes.addFlashAttribute("error", "删除失败!");

return "redirect:/allreaders.html";

@RequestMapping("/reader_info.html")

public ModelAndView toReaderInfo(HttpServletRequest request) {

ReaderCard readerCard = (ReaderCard) request.getSession().getAttribute("readercard");

ReaderInfo readerInfo = readerInfoService.getReaderInfo(readerCard.getReaderId());

ModelAndView modelAndView = new ModelAndView("reader_info");

modelAndView.addObject("readerinfo", readerInfo);

return modelAndView;


return "404";

图书管理控制层:

@Controller

public class BookController {

@Autowired

private BookService bookService;

@Autowired

private LendService lendService;

private Date getDate(String pubstr) {

try {

SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");


modelAndView.addObject("books", books);

return modelAndView;

@RequestMapping("/book_add.html")

public ModelAndView addBook() {

return new ModelAndView("admin_book_add");

@RequestMapping("/book_add_do.html")

public String addBookDo(@RequestParam(value = "pubstr") String pubstr, Book book, RedirectAttributes redirectAttributes) {

book.setPubdate(getDate(pubstr));

if (bookService.addBook(book)) {

redirectAttributes.addFlashAttribute("succ", "图书添加成功!");

} else {

redirectAttributes.addFlashAttribute("succ", "图书添加失败!");

return "redirect:/admin_books.html";


@RequestMapping("reader_add.html")

public ModelAndView readerInfoAdd() {

return new ModelAndView("admin_reader_add");

@RequestMapping("reader_add_do.html")

public String readerInfoAddDo(String name, String sex, String birth, String address, String phone, String password, RedirectAttributes redirectAttributes) {

ReaderInfo readerInfo = getReaderInfo(0, name, sex, birth, address, phone);

long readerId = readerInfoService.addReaderInfo(readerInfo);

readerInfo.setReaderId(readerId);

if (readerId > 0 && readerCardService.addReaderCard(readerInfo, password)) {

redirectAttributes.addFlashAttribute("succ", "添加读者信息成功!");

} else {

private BookService bookService;

@Autowired

private LendService lendService;

private Date getDate(String pubstr) {

try {

SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");

return df.parse(pubstr);

} catch (ParseException e) {

e.printStackTrace();

return new Date();

@RequestMapping("/queryBook.html")

public ModelAndView queryBookDo(String searchWord) {

if (bookService.matchBook(searchWord)) {

ArrayList<Book> books = bookService.queryBook(searchWord);


readerInfo.setAddress(address);

readerInfo.setName(name);

readerInfo.setReaderId(readerId);

readerInfo.setPhone(phone);

readerInfo.setSex(sex);

readerInfo.setBirth(date);

return readerInfo;

@RequestMapping("allreaders.html")

public ModelAndView allBooks() {

ArrayList<ReaderInfo> readers = readerInfoService.readerInfos();

ModelAndView modelAndView = new ModelAndView("admin_readers");

redirectAttributes.addFlashAttribute("error", "旧密码错误!");

return "redirect:/admin_repasswd.html";

@RequestMapping("/reader_repasswd.html")

public ModelAndView reReaderPasswd() {

return new ModelAndView("reader_repasswd");

@RequestMapping("/reader_repasswd_do")

public String reReaderPasswdDo(HttpServletRequest request, String oldPasswd, String newPasswd, String reNewPasswd, RedirectAttributes redirectAttributes) {

ReaderCard reader = (ReaderCard) request.getSession().getAttribute("readercard");

long id = reader.getReaderId();

String password = loginService.getReaderPassword(id);

if (password.equals(oldPasswd)) {

if (loginService.readerRePassword(id, newPasswd)) {

redirectAttributes.addFlashAttribute("succ", "密码修改成功!");

return "redirect:/reader_repasswd.html";

e.printStackTrace();

return new Date();

@RequestMapping("/queryBook.html")

public ModelAndView queryBookDo(String searchWord) {

if (bookService.matchBook(searchWord)) {

ArrayList<Book> books = bookService.queryBook(searchWord);

ModelAndView modelAndView = new ModelAndView("admin_books");

modelAndView.addObject("books", books);

return modelAndView;

} else {

return new ModelAndView("admin_books", "error", "没有匹配的图书");

@RequestMapping("/reader_querybook_do.html")

public ModelAndView readerQueryBookDo(String searchWord) {


public void setLoginService(LoginService loginService) {

this.loginService = loginService;

@RequestMapping(value = {"/", "/login.html"})

public String toLogin(HttpServletRequest request) {

request.getSession().invalidate();

return "index";

@RequestMapping("/logout.html")

public String logout(HttpServletRequest request) {

request.getSession().invalidate();

return "redirect:/login.html";


readerInfo.setAddress(address);

readerInfo.setName(name);

readerInfo.setReaderId(readerId);

readerInfo.setPhone(phone);

readerInfo.setSex(sex);

readerInfo.setBirth(date);

return readerInfo;

@RequestMapping("allreaders.html")

public ModelAndView allBooks() {

ArrayList<ReaderInfo> readers = readerInfoService.readerInfos();

redirectAttributes.addFlashAttribute("error", "密码修改失败!");

return "redirect:/reader_repasswd.html";

} else {

redirectAttributes.addFlashAttribute("error", "旧密码错误!");

return "redirect:/reader_repasswd.html";

//配置404页面

@RequestMapping("*")

public String notFind() {

return "404";

图书管理控制层:

@Controller

public class BookController {

@Autowired

private BookService bookService;

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值