作者主页:Java毕设网
简介:Java领域优质创作者、Java项目、学习资料、技术互助
文末获取源码
一、项目介绍
该项目分为管理员与读者两种角色,主要功能有:
1. 登录、注销、修改密码
2. 管理员主要功能包括:图书管理、读者管理、借还管理。对图书信息的增删改查、查看读者、查看借阅记录等;
3. 读者对图书信息的查看查询、修改个人信息、查看借阅记录
共7张表;
二、环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。
2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA;
3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可
4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS;
5.是否Maven项目: 是;查看源码目录中是否包含pom.xml;若包含,则为maven项目,否则为非maven项目
6.数据库:MySql 8.0版本;
三、技术栈
数据库:mysql5.7
后端框架: SpringBoot
HTML模板: ThymeLeaf
持久层: Mybatis
UI: Bootstrap
登录验证和用户权限: SpringSecurity
四、使用说明
1. 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件;
2. 使用IDEA/Eclipse/MyEclipse导入项目,Eclipse/MyEclipse导入时,若为maven项目请选择maven;
若为maven项目,导入成功后请执行maven clean;maven install命令,然后运行;
3. 将项目中jdbc.properties配置文件中的数据库配置改为自己的配置;
4. 运行项目,输入localhost:8080/ 登录
五、运行截图
六、相关代码
管理端图书控制器
@Controller
@RequestMapping("/admin/book")
public class AdminBookController {
@Autowired
private BookMapper bookMapper;
@RequestMapping("/getAll")
public String getAll(Model model) {
List<Book> books = bookMapper.getAllBook();
model.addAttribute("books", books);
return "admin/books";
}
@RequestMapping("/info/{id}")
public String info(Model model, @PathVariable("id") String id) {
Book book = bookMapper.getBookById(id);
model.addAttribute("book", book);
return "admin/book_info";
}
@RequestMapping("/toEditPage/{id}")
public String toEditPage(Model model, @PathVariable("id") String id) {
Book book = bookMapper.getBookById(id);
model.addAttribute("book", book);
return "admin/book_edit";
}
@RequestMapping("/update")
public String update(Book book) {
bookMapper.updateBook(book);
return "redirect:/admin/book/getAll";
}
@RequestMapping("/delete/{id}")
public String delete(@PathVariable("id") long id) {
bookMapper.deleteBook(id);
return "redirect:/admin/book/getAll";
}
@RequestMapping("/toAddPage")
public String toAddPage() {
return "admin/book_add";
}
@RequestMapping("/add")
public String add(Book book) {
bookMapper.addBook(book);
return "redirect:/admin/book/getAll";
}
@RequestMapping("/search")
public String search(String keyword, Model model) {
List<Book> books = bookMapper.searchBook(keyword);
model.addAttribute("books", books);
return "admin/book_search_result";
}
}
用户管理控制器
@Controller
public class UserController {
@Autowired
private UserMapper userMapper;
@RequestMapping("/toChPwdPage")
public String toChangePasswordPage() {
return "password";
}
@RequestMapping("/changePassword")
public String changePassword(HttpSession session, String newPassword) {
String username = (String) session.getAttribute("username");
userMapper.changePassword(username, newPassword);
return "redirect:/";
}
@RequestMapping("/checkPassword")
@ResponseBody
public String checkPassword(@RequestParam("password") String password, HttpSession session) {
String username = (String) session.getAttribute("username");
String realPassword = userMapper.getPassword(username);
if (realPassword.equals(password))
return "1";
else
return "0";
}
}