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

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

运行环境

Java≥8、MySQL≥5.7

开发工具

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

适用

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

功能说明

20220519002032

20220519002033

20220519002034

20220519002036

20220519002037

20220519002038

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

项目介绍

该项目分为管理员与读者两种角色,主要功能有:

  1. 登录、注销、修改密码 2.  管理员主要功能包括:图书管理、读者管理、借还管理。对图书信息的增删改查、查看读者、查看借阅记录等;

  2. 读者对图书信息的查看查询、修改个人信息、查看借阅记录

共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

使用说明

本项目使用maven进行管理,详细安装教程自行百度 1.  需下载mysql图形化管理工具(例如Navicat),新建数据库library,右键数据库–>运行项目中的library.sql脚本 2.  打开项目(idea或eclipse皆可,但需配置好maven环境),打开src/main/resources/application.yml,将数据库的username和password修改成你自己的mysql的用户名和密码 3.  找到BookmanagerApplication类运行main方法,打开浏览器,网址栏输入localhost:8080访问系统

  1. 如果不想用IDE打开项目而是想直接运行的朋友们,在目录下打开cmd键入mvn package命令,然后在target/目录下会生成对应的jar包,在cmd用“java -jar jar包名”运行即可

注意事项

  1. 高版本mysql在登录时可能会报空指针错误,出现问题的建议安装并使用mysql5.7版本

用户管理控制层:

/**

  • @Descriiption 用户管理

  • @Author by yy

*/

@Api(tags = “用户管理”)

@RestController

@RequestMapping(“/user”)

public class UsersController {

@Autowired

private UserService userService;

@ApiOperation(“用户列表”)

@PostMapping(“/list”)

public R getUsers(@RequestBody PageIn pageIn) {

if (pageIn == null) {

return R.fail(CodeEnum.PARAM_ERROR);

// 封装分页出参对象

PageInfo userList = userService.getUserList(pageIn);

PageOut pageOut = new PageOut();

pageOut.setCurrPage(userList.getPageNum());

pageOut.setPageSize(userList.getPageSize());

pageOut.setTotal((int) userList.getTotal());

List outs = new ArrayList<>();

for (Users users : userList.getList()) {

UserOut out = new UserOut();

BeanUtils.copyProperties(users,out);

out.setIdent(ConvertUtil.identStr(users.getIdentity()));

out.setBirth(DateUtil.format(users.getBirthday(),Constants.DATE_FORMAT));

outs.add(out);

pageOut.setList(outs);

return R.success(CodeEnum.SUCCESS,pageOut);

/**

  • 添加读者操作

  • @param users

  • @return

*/

@ApiOperation(“添加读者”)

@ResponseBody

@PostMapping(“/addReader”)

public R addReader(Users users) {

if (users == null) {

return R.fail(CodeEnum.PARAM_ERROR);

if(StringUtils.isEmpty(users.getAvatar())) {

return R.fail(CodeEnum.USER_HEAD_PIC_ERROR);

if(StringUtils.isEmpty(users.getUsername())) {

return R.fail(CodeEnum.USERNAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getNickname())) {

return R.fail(CodeEnum.NICKNAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getTel())) {

return R.fail(CodeEnum.USER_MOBILE_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getEmail())) {

return R.fail(CodeEnum.USER_EMAIL_NOT_EXIST_ERROR);

Users byUsername = userService.findByUsername(users.getUsername());

if(byUsername!=null){

return R.fail(CodeEnum.USER_NAME_IS_EXIST_ERROR);

// 读者默认是普通用户

users.setIsAdmin(1);

Users users1 = userService.addUser(users);

if(users1==null){

return R.fail(CodeEnum.USER_ADD_ERROR);

return R.success(CodeEnum.SUCCESS);

/**

  • 编辑用户操作

  • @param users

  • @return

*/

@ApiOperation(“编辑用户”)

@ResponseBody

@PostMapping(“/edit”)

public R modifyUsers(Users users) {

if (users == null) {

return R.fail(CodeEnum.PARAM_ERROR);

if(StringUtils.isEmpty(users.getAvatar())) {

return R.fail(CodeEnum.USER_HEAD_PIC_ERROR);

if(StringUtils.isEmpty(users.getUsername())) {

return R.fail(CodeEnum.USERNAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getNickname())) {

return R.fail(CodeEnum.NICKNAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getTel())) {

return R.fail(CodeEnum.USER_MOBILE_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(users.getEmail())) {

return R.fail(CodeEnum.USER_EMAIL_NOT_EXIST_ERROR);

Users byUsername = userService.findByUsername(users.getUsername());

if(byUsername!=null){

if(!byUsername.getId().equals(users.getId())){

return R.fail(CodeEnum.USER_NAME_IS_EXIST_ERROR);

if(!userService.updateUser(users)){

return R.fail(CodeEnum.USER_EDIT_ERROR);

return R.success(CodeEnum.SUCCESS);

@ApiOperation(“用户详情”)

@GetMapping(“/detail”)

public R userDetail(Integer id) {

Users user = userService.findUserById(id);

if (user!=null) {

UserOut out = new UserOut();

BeanUtils.copyProperties(user,out);

out.setBirth(DateUtil.format(user.getBirthday(),Constants.DATE_FORMAT));

out.setIdent(ConvertUtil.identStr(user.getIdentity()));

return R.success(CodeEnum.SUCCESS,out);

return R.fail(CodeEnum.NOT_FOUND);

@ApiOperation(“删除用户”)

@GetMapping(“/delete”)

public R delUsers(Integer id) {

userService.deleteUser(id);

return R.success(CodeEnum.SUCCESS);

@ApiOperation(“获取当前用户登陆信息”)

@GetMapping(“/currUser”)

public R getCurrUser() {

Object principal = SecurityContextHolder.getContext().getAuthentication().getPrincipal();

if (principal!=null) {

Map<String,Object> map = BeanUtil.beanToMap(principal);

String username = (String) map.get(“username”);

if (StrUtil.isNotBlank(username)) {

Users users = userService.findByUsername(username);

UserOut out = new UserOut();

BeanUtils.copyProperties(users,out);

out.setBirth(DateUtil.format(users.getBirthday(),Constants.DATE_FORMAT));

Integer identity = users.getIdentity();

String ident = “”;

if (identity == Constants.STUDENT) {

ident = Constants.STU_STR;

}else if (identity == Constants.TEACHER) {

ident = Constants.TEA_STR;

}else if (identity == Constants.OTHER) {

ident = Constants.OTHER_STR;

}else if (identity == Constants.ADMIN) {

ident = Constants.ADMIN_STR;

out.setIdent(ident);

return R.success(CodeEnum.SUCCESS,out);

return R.fail(CodeEnum.USER_NOT_FOUND);

借阅管理控制层:

/**

  • @Descriiption 借阅管理

  • @Author by yy

*/

@Api(tags = “借阅管理”)

@RestController

@RequestMapping(“/borrow”)

public class BorrowController {

@Autowired

private BorrowService borrowService;

@Autowired

private BookService bookService;

@ApiOperation(“借阅列表”)

@GetMapping(“/list”)

public R getBorrowList(Integer userId) {

return R.success(CodeEnum.SUCCESS,borrowService.findAllBorrowByUserId(userId));

@ApiOperation(“借阅图书”)

@PostMapping(“/add”)

public R addBorrow(@RequestBody Borrow borrow) {

Integer result = borrowService.addBorrow(borrow);

if (result == Constants.BOOK_BORROWED) {

return R.success(CodeEnum.BOOK_BORROWED);

}else if (result == Constants.USER_SIZE_NOT_ENOUGH) {

return R.success(CodeEnum.USER_NOT_ENOUGH);

}else if (result == Constants.BOOK_SIZE_NOT_ENOUGH) {

return R.success(CodeEnum.BOOK_NOT_ENOUGH);

return R.success(CodeEnum.SUCCESS,Constants.OK);

@ApiOperation(“编辑借阅”)

@PostMapping(“/update”)

public R modifyBorrow(@RequestBody Borrow borrow) {

return R.success(CodeEnum.SUCCESS,borrowService.updateBorrow(borrow));

@ApiOperation(“借阅详情”)

@GetMapping(“/detail”)

public R borrowDetail(Integer id) {

return R.success(CodeEnum.SUCCESS,borrowService.findById(id));

@ApiOperation(“删除归还记录”)

@GetMapping(“/delete”)

public R delBorrow(Integer id) {

borrowService.deleteBorrow(id);

return R.success(CodeEnum.SUCCESS);

@ApiOperation(“已借阅列表”)

@GetMapping(“/borrowed”)

public R borrowedList(Integer userId) {

List outs = new ArrayList<>();

if (userId!=null&&userId>0) {

// 获取所有 已借阅 未归还书籍

List borrows = borrowService.findBorrowsByUserIdAndRet(userId, Constants.NO);

for (Borrow borrow : borrows) {

BackOut backOut = new BackOut();

BookOut out = bookService.findBookById(borrow.getBookId());

BeanUtils.copyProperties(out,backOut);

backOut.setBorrowTime(DateUtil.format(borrow.getCreateTime(),Constants.DATE_FORMAT));

String endTimeStr = DateUtil.format(borrow.getEndTime(), Constants.DATE_FORMAT);

backOut.setEndTime(endTimeStr);

// 判断是否逾期

String toDay = DateUtil.format(new Date(), Constants.DATE_FORMAT);

int i = toDay.compareTo(endTimeStr);

if (i>0) {

backOut.setLate(Constants.YES_STR);

}else {

backOut.setLate(Constants.NO_STR);

outs.add(backOut);

return R.success(CodeEnum.SUCCESS,outs);

@ApiOperation(“归还书籍”)

@PostMapping(“/ret”)

public R retBook(Integer userId, Integer bookId) {

// 归还图书

borrowService.retBook(userId,bookId);

return R.success(CodeEnum.SUCCESS);

图书管理控制层:

/**

  • @Descriiption 图书管理

  • @Author by yy

*/

@Api(tags = “图书管理”)

@RestController

@RequestMapping(“/book”)

public class BookController {

@Autowired

private BookService bookService;

@ApiOperation(“图书搜索列表”)

@PostMapping(“/list”)

public R getBookList(@RequestBody PageIn pageIn) {

if (pageIn == null) {

return R.fail(CodeEnum.PARAM_ERROR);

return R.success(CodeEnum.SUCCESS,bookService.getBookList(pageIn));

/**

  • 添加图片操作

  • @param book

  • @return

*/

@ApiOperation(“添加图书”)

@ResponseBody

@PostMapping(“/add”)

public R addBook(Book book) {

if(StringUtils.isEmpty(book.getName())){

return R.fail(CodeEnum.BOOK_NAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getIsbn())){

return R.fail(CodeEnum.BOOK_ISBN_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getPic())){

return R.fail(CodeEnum.BOOK_IMAGE_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getAuthor())){

return R.fail(CodeEnum.BOOK_AUTHOR_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getType())){

return R.fail(CodeEnum.BOOK_TYPE_NOT_EXIST_ERROR);

BookOut bookByIsbn = bookService.findBookByIsbn(book.getIsbn());

if(bookByIsbn.getName()!=null){

return R.fail(CodeEnum.BOOK_ISBN_EXIST_ERROR);

if(bookService.addBook(book)==null){

return R.fail(CodeEnum.BOOK_ADD_ERROR);

return R.success(CodeEnum.SUCCESS);

/**

  • 编辑图书

  • @param book

  • @return

*/

@ApiOperation(“编辑图书”)

@ResponseBody

@PostMapping(“/edit”)

public R editBook(Book book) {

if(StringUtils.isEmpty(book.getName())){

return R.fail(CodeEnum.BOOK_NAME_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getIsbn())){

return R.fail(CodeEnum.BOOK_ISBN_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getPic())){

return R.fail(CodeEnum.BOOK_IMAGE_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getAuthor())){

return R.fail(CodeEnum.BOOK_AUTHOR_NOT_EXIST_ERROR);

if(StringUtils.isEmpty(book.getType())){

return R.fail(CodeEnum.BOOK_TYPE_NOT_EXIST_ERROR);

BookOut bookByIsbn = bookService.findBookByIsbn(book.getIsbn());

if(bookByIsbn.getName()!=null){

if(!bookByIsbn.getId().equals(book.getId())){

return R.fail(CodeEnum.BOOK_ISBN_EXIST_ERROR);

if(!bookService.updateBook(book)){

return R.fail(CodeEnum.BOOK_EDIT_ERROR);

return R.success(CodeEnum.SUCCESS);

@ApiOperation(“图书详情”)

@GetMapping(“/detail”)

public R bookDetail(Integer id) {

return R.success(CodeEnum.SUCCESS,bookService.findBookById(id));

@ApiOperation(“图书详情 根据ISBN获取”)

@GetMapping(“/detailByIsbn”)

public R bookDetailByIsbn(String isbn) {

BookOut bookByIsbn = bookService.findBookByIsbn(isbn);

if(bookByIsbn.getId()==null){

return R.fail(CodeEnum.BOOK_NOT_EXIST_ERROR);

return R.success(CodeEnum.SUCCESS,bookByIsbn);

@ApiOperation(“删除图书”)

@GetMapping(“/delete”)

public R delBook(Integer id) {

bookService.deleteBook(id);

return R.success(CodeEnum.SUCCESS);


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【资源说明】 1、基于Java+Springboot+MySQL+Thymeleaf 架构的电影聚合系统源码+数据库+项目说明.zip 2、该资源包括项目的全部源码,下载可以直接使用! 3、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和毕设项目,作为参考资料学习借鉴。 4、本资源作为“参考资料”如果需要实现其他功能,需要能看懂代码,并且热爱钻研,自行调试。 基于Java+Springboot+MySQL+Thymeleaf 架构的电影聚合系统源码+数据库+项目说明.zip > 一个采用 SpringBoot 架构的电影聚合 JavaWeb 项目,适用于 SpringBoot 练手项目 #### 二、运行环境 * IDEA * JDK 8 * MySQL([数据库链接:db_film](https://github.com/volewu/Film/blob/master/db_cms.sql)) #### 三、项目技术 * Spring && Spring Boot && Spring Sectuity * Spring Data Jpa * EsayUI + Bootstrap * thymeleaf * ckeditor * 运行截图 ![film](https://github.com/volewu/Film/blob/master/preview/film.gif?raw=true) ​ #### 四、姿势点 ##### 1、 SpringSecurity 中得到登入的用户名 ```html th:text="${#httpServletRequest.remoteUser}" ``` ##### 2、thymeleaf 问题 ```html /*<![CDATA[*/ 中不扫描该注释中的代码 /*]]>*/ //时间转换 ${#dates.format(film.publishDate,'yyyy-MM-dd HH:mm:ss')} ``` ##### 3、jpa 中格式化时间 [CustomDateSerializer.java](https://github.com/volewu/Film/blob/master/src/main/java/com/vole/film/util/CustomDateSerializer.java) ```java @JsonSerialize(using = CustomDateSerializer.class) public Date getPublishDate() { return publishDate; } ``` ##### 4、jpa 中 Repository 自定义方法 [WebSiteInfoRepository.java](https://github.com/volewu/Film/blob/master/src/main/java/com/vole/film/repository/WebSiteInfoRepository.java) ```java // 1 代表第一个参数 @Query(value = "select * from t_info where film_id=?1", nativeQuery = true) List<WebSiteInfo> getByFilmId(Integer filmId); ``` ##### 5、jpa 中模糊查询拼接 [FilmServiceImpl.java](https://github.com/volewu/Film/blob/master/src/main/java/com/vole/film/service/impl/FilmServiceImpl.java) ```java @Override public List<Film> list(Film film, Integer page, Integer pageSize) { Pageable pageable = new PageRequest(page, pageSize, Sort.Direction.DESC, "publishDate"); Page<Film> filmPage = filmRepository.findAll((root, criteriaQuery, cb) -> { Predicate predicate = cb.conjunction(); if (film != null) { if (Str
基于引用和引用提供的信息,可以得知存在基于javawebmysql图书管理系统。这样的系统可以使用Java编程语言和JSP技术进行开发,并且使用MySQL作为数据库。在这个系统中,用户可以通过用户模块查看公告和图书信息。图书管理员和系统管理员有不同的权限,可以进行图书借阅管理和系统管理等操作。 这样的图书管理系统可以提供以下功能: 1. 用户模块:用户可以查看图书管理员发布的公告信息,以及通过分页显示的方式查看图书信息。 2. 图书借阅功能:用户可以借阅图书,并对借阅的图书进行管理,例如归还、续借等操作。 3. 图书管理员模块:图书管理员可以对图书进行管理,包括添加、修改、删除图书信息,以及处理用户的图书借阅请求。 4. 系统管理员模块:系统管理员可以对整个系统进行管理,包括用户管理、图书管理员管理和公告管理等。 使用javawebmysql开发图书管理系统的好处是,Java作为一门常用的编程语言,具有广泛的应用范围和良好的跨平台性能。JSP技术可以方便地与Java后台逻辑交互,实现动态网页的生成和交互。而MySQL作为一种常用的关系型数据库管理系统,具有稳定可靠、性能高效等特点,适合用于存储和管理图书信息。 综上所述,基于javawebmysql图书管理系统可以提供完善的用户功能和管理员功能,满足用户对图书借阅和管理的需求。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值