从零开始搭建一个 SpringBoot 脚手架
导航
上一章地址:
下一章地址:二、从零开始-用户管理
说明
- 贴代码时会贴整个类的全量代码,防止找不到我改的是哪个
- 创建的类在哪个包下不会单独说明,因为全量代码里有 package 直接看这个就可以了
- gitee 代码存放地址 https://gitee.com/mxw13579/study-scaffold 可以直接下下来看更加清晰
一、初始化项目
1.1、new Project
改成这样就可以了,然后一直下一步
1.2、修改 pom 文件
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.7.16</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.lzl.study.scaffold</groupId>
<artifactId>StudyScaffold</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>StudyScaffold</name>
<description>StudyScaffold</description>
<properties>
<java.version>1.8</java.version>
<druid.version>1.1.18</druid.version>
<mysql.version>8.0.14</mysql.version>
</properties>
<dependencies>
<!-- 自定义验证注解 -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<!-- redis -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
<!-- redisson -->
<dependency>
<groupId>org.redisson</groupId>
<artifactId>redisson-spring-boot-starter</artifactId>
<version>3.19.3</version>
</dependency>
<!-- hutool -->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>5.8.16</version>
</dependency>
<!-- jdbc -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!-- mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!-- druid 数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>${druid.version}</version>
</dependency>
<!-- mybatisPlus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.4.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<excludes>
<exclude>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</exclude>
</excludes>
</configuration>
</plugin>
</plugins>
</build>
</project>
1.3、修改 application.yml 文件
这个文件一开始是没有的,把自带的 application 的给删除了,然后新增一个 application.yml 文件
server:
port: 2005
spring:
application:
name: study-scaffold
datasource:
type: com.alibaba.druid.pool.DruidDataSource
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.1.106:3306/studyscaffold?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC
username: root
password: lzlStudy
# 开启mp的日志(输出到控制台)
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
数据库 sql 在下面会贴,先这样写着,等一下搞定数据库了然后在运行
1.4、新建数据库
首先新建一个数据库
然后新建一个数据库表方便我们操作
1.5、新建表
CREATE TABLE `t_sys_user` (
`id` bigint DEFAULT NULL COMMENT '主键',
`name` varchar(32) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '姓名',
`password` varchar(64) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '密码',
`phone` varchar(32) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '手机号',
`account` varchar(64) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '登录账号',
`sex` int DEFAULT NULL COMMENT '性别,0女1男2未知',
`id_card` varchar(32) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '身份证号码',
`email` varchar(64) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '邮箱',
`dept_id` bigint DEFAULT NULL COMMENT '部门ID,不允许多部门',
`user_post_ids` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '岗位ID集合,允许多岗位',
`role_ids` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '角色ID集合,允许多角色',
`user_status` int DEFAULT NULL COMMENT '用户状态 0为启用1为禁用',
`parent_id` bigint DEFAULT NULL COMMENT '父部门ID',
`password_update_data` datetime DEFAULT NULL COMMENT '最后密码修改时间',
`login_date` datetime DEFAULT NULL COMMENT '最后登录时间',
`login_ip` varchar(64) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '最后登录IP',
`remark` varchar(255) COLLATE utf8mb4_general_ci DEFAULT NULL COMMENT '备注',
`tenant_id` int DEFAULT NULL COMMENT '租户号',
`revision` int DEFAULT NULL COMMENT '乐观锁',
`created_by` bigint DEFAULT NULL COMMENT '创建人',
`created_time` datetime DEFAULT NULL COMMENT '创建时间',
`updated_by` bigint DEFAULT NULL COMMENT '更新人',
`updated_time` datetime DEFAULT NULL COMMENT '更新时间',
UNIQUE KEY `account_index` (`account`) USING BTREE COMMENT '账号索引',
UNIQUE KEY `phone_index` (`phone`) USING BTREE COMMENT '手机号索引'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='用户表';
到这里项目也就初始化完成了,后续开始编写 用户管理功能