文章目录
前言
作为一名开发人员我们知道每个标准的的管理系统有些部分是必不可少的:
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
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,原创不易,请大佬们多多支持,谢谢!
其他
可以在微信公众号搜索“程序员阿坤”或者扫描下方二维码,加入我的公众号,目前“项目学习小组”正在热更基于springboot+vue的前后端分离的期刊在线投稿系统(技术和功能都做了调整有很多亮点!)公众号会有详细介绍,另外公众号会定时分享学习方法,以及一些工作中的技术干货一起学习交流!