springboot+thymeleaf+mysql实现脚手架权限管理系统(超详细讲解)


前言

作为一名开发人员我们知道每个标准的的管理系统有些部分是必不可少的:

1.用户管理
2.角色管理
3.菜单管理
4.日志管理
5.数据备份

我大概列出这几个模块,那么每次设计实现一个系统都需要做这些重复的模块功能是不是不符合我们架构设计的规范,因此我们需要把这些相同的部分抽离出来,作为一个项目开发的基础脚手架系统,之后做开发只需要在这个系统的基础上进行新功能的开发,那就很方便了。


一、开发环境配置

1.开发工具

Eclipse

2.后台框架

SpringBoot

3.前端模板

SpringBoot自带前端模板:thymeleaf

4.数据库

MySql8.0

5.服务器

SpringBoot内嵌tomcat

二、数据库设计

1.用户表 - cuinn_user

在这里插入图片描述

2.角色表 - cuinn_role

在这里插入图片描述

3.角色权限表 - cuinn_role_authorities

## 2.读入数据

4.菜单表 - cuinn_menu

在这里插入图片描述

5.日志表 - cuinn_operater_log

在这里插入图片描述

6.数据备份表 - cuinn_operater_log

在这里插入图片描述

三、系统设计

1.系统结构

在这里插入图片描述

2.代码结构

包结构:
在这里插入图片描述
系统架构模式:
B/S模式,浏览器/服务端 模式
在这里插入图片描述

四、系统实现

1.用户登录

在这里插入图片描述
关键逻辑代码:

@RequestMapping(value = "/login", method=RequestMethod.POST)
	@ResponseBody
	public Result<Boolean> login(HttpServletRequest request, User user, String cpacha) {
		if(user == null) {
			return Result.error(CodeMsg.DATA_ERROR);
		}
		//统一实体验证
		CodeMsg validate = ValidateEntityUtil.validate(user);
		
		if(validate.getCode() != CodeMsg.SUCCESS.getCode()) {
			return Result.error(validate);
		}
		//验证码校验
		if(StringUtils.isEmpty(cpacha)) {
			return Result.error(CodeMsg.CPACHA_EMPTY);
		}
		//说明验证码不为空,从sessino里获取验证码
		Object attribute = request.getSession().getAttribute("admin_login");
		if(attribute == null) {
			return Result.error(CodeMsg.SESSION_EXPIRED);
		}
		//表示session未失效,进一步判断验证码是否正确
		if(!cpacha.equalsIgnoreCase(attribute.toString())) {
			return Result.error(CodeMsg.CPACHA_ERROR);
		}
		//开始查询数据库
		User findByUsername = userService.findByUsername(user.getUsername());
		if(findByUsername == null) {
			return Result.error(CodeMsg.ADMIN_USERNAME_NO_EXIST);
		}
		if(!findByUsername.getPassword().equals(user.getPassword())) {
			return Result.error(CodeMsg.ADMIN_PASSWORD_ERROR);
		}
		//判断用户状态是否可用
		if(findByUsername.getStatus() == User.ADMIN_USER_STATUS_UNABLE) {
			return Result.error(CodeMsg.ADMIN_USER_UNABLE);
		}
		//判断用户所属角色是否可用
		if(findByUsername.getRole() == null || findByUsername.getRole().getStatus() == Role.ADMIN_ROLE_STATUS_UNABLE){
			return Result.error(CodeMsg.ADMIN_USER_ROLE_UNABLE);
		}
		//判断用户所属角色是否有权限
		if(findByUsername.getRole().getAuthorities() == null || findByUsername.getRole().getAuthorities().size() == 0) {
			return Result.error(CodeMsg.ADMIN_USER_ROLE_AUTHORITIES_EMPTY);
		}
		//密码正确,将登录信息放入session
		request.getSession().setAttribute(SessionConstant.SESSION_USER_LOGIN_KEY, findByUsername);
		//销毁session中的验证码
		request.getSession().setAttribute("admin_login", null);
		log.info("user="+user);
		operaterLogService.add("用户【"+ findByUsername.getUsername() + "】于【"+ StringUtil.getFormatterDate(new Date(), "yyyy-MM-dd HH:mm:ss") +"】登录系统!");
		return Result.success(true);
	}

2.后台首页

在这里插入图片描述

3.菜单模块

在这里插入图片描述

4.角色模块

在这里插入图片描述

5.用户模块

在这里插入图片描述

6.日志模块

在这里插入图片描述

7.数据备份

在这里插入图片描述
附上完整pom.xml文件

<?xml version="1.0" encoding="UTF-8"?>

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
  <modelVersion>4.0.0</modelVersion>
  <packaging>war</packaging>
  <parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.3.11.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
  </parent>
 
  <groupId>com.cuinn</groupId>
  <artifactId>base</artifactId>
  <version>0.0.1-SNAPSHOT</version>

  <name>base</name>
  <!-- FIXME change it to the project's website -->
  <url>http://www.example.com</url>

  <properties>
    <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    <maven.compiler.source>1.8</maven.compiler.source>
    <maven.compiler.target>1.8</maven.compiler.target>
    <java.version>1.8</java.version>
  </properties>

  <dependencies>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-freemarker</artifactId>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
	<dependency>
	    <groupId>org.springframework.boot</groupId>
	    <artifactId>spring-boot-starter-data-jpa</artifactId>
	</dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <scope>runtime</scope>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-test</artifactId>
      <scope>test</scope>
      <exclusions>
        <exclusion>
          <groupId>org.junit.vintage</groupId>
          <artifactId>junit-vintage-engine</artifactId>
        </exclusion>
      </exclusions>
    </dependency>
    <dependency>
  	  <groupId>junit</groupId>
  	  <artifactId>junit</artifactId>
  	  <version>4.0</version>
  	  <scope>test</scope>
  	</dependency>
  	<dependency>
	  <groupId>org.springframework.boot</groupId>
	  <artifactId>spring-boot-devtools</artifactId>
	  <optional>true</optional>
	</dependency>
	<dependency>
      <groupId>org.apache.commons</groupId>
      <artifactId>commons-lang3</artifactId>
    </dependency>
    <dependency>
	  <groupId>commons-codec</groupId>
	  <artifactId>commons-codec</artifactId>
 	</dependency>
 	<dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.2.31</version>
    </dependency>	
  </dependencies>
  

  <build>
    <plugins>
      <plugin>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-maven-plugin</artifactId>
      </plugin>
    </plugins>
  </build>

</project>

总结

好久没更新了,今天闲来写一篇文章,限于篇幅,代码不过多粘贴,需要源代码请联系我QQ:1172820051,原创不易,请大佬们多多支持,谢谢!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
书城管理系统主要分为前台和后台两部分,前台主要是面向读者的,包括图书展示、购买、借阅等功能;后台主要是面向管理员的,包括图书管理、用户管理、订单管理等功能。 下面是一个基于SpringBoot + Thymeleaf + Mybatis的书城管理系统的简单实现: 1. 数据库设计 - 用户表:id, username, password, email, phone - 图书表:id, book_name, author, price, stock, sales, image - 订单表:id, user_id, book_id, status, create_time, update_time 2. 实体类设计 - 用户类:包括id、用户名、密码、邮箱、电话等属性 - 图书类:包括id、书名、作者、价格、库存、销量、图片等属性 - 订单类:包括id、用户id、图书id、状态、创建时间、更新时间等属性 3. DAO层设计 - 用户DAO:包括增删改查等操作,使用Mybatis注解或XML方式实现 - 图书DAO:包括增删改查等操作,使用Mybatis注解或XML方式实现 - 订单DAO:包括增删改查等操作,使用Mybatis注解或XML方式实现 4. 服务层设计 - 用户服务:包括用户注册、登录、修改密码、查询用户信息等方法 - 图书服务:包括图书查询、购买、借阅、归还等方法 - 订单服务:包括订单生成、查询、修改状态等方法 5. 控制层设计 - 前台控制器:包括图书展示、购买、借阅等操作的处理 - 后台控制器:包括图书管理、用户管理、订单管理等操作的处理 6. 视图层设计 - 前台视图:包括图书展示、购买、借阅等页面的设计 - 后台视图:包括图书管理、用户管理、订单管理等页面的设计 以上是一个简单的基于SpringBoot + Thymeleaf + Mybatis的书城管理系统的设计实现,可以根据实际需求进行调整和扩展。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

优柔寡断的阿坤~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值