一、权限后台管理系统介绍
本系统旨在实现一个基于角色控制的权限管理系统,使用 Spring Boot 构建后端 API接口,Vue.js 构建前端 SPA 应用(单页面应用),实现首页、登录页面、用户管理、角色管理、权限管理、产品管理、订单管理等模块的管理功能。前后端分离
技术架构(技术栈):从两部分来说
服务端:主要采用是SpringBoot3.x、Mybatis 3.x、SpringSecurity6.x、MySQL8.x、Druid连接池
客户端: 主要采用是Vue3.x + ElementPlus
二、项目搭建
什么是聚合工程
所谓聚合工程,实际上就是对项目分模块,Maven中将项目可以创建 父工程(pom工程),子工程(非pom工程)。
在 Maven 父工程中可以创建 多个子工程(项目),多个组件之间可以通过父工程 对各个子工程 做jar的统一管理 和 统一构建(多个组件之间可以相互依赖,实现组件的复用)。
传统的软件项目,大多采用分层的方式(Dao、Serivce、Controller);
现在互联网项目越来越复杂,一般情况下,一个项目包括多个模块,按照业务来分(订单模块、VIP模块、支付模块、用户模块...);
传统分层 vs 业务模块化
|
维度 |
传统分层(DAO/Service/Controller) |
业务模块化(订单/用户/VIP) |
|
核心目标 |
按技术职责分层 |
按业务领域垂直拆分,使项目结构更加清楚 |
|
复用性 |
同一业务逻辑分散在不同层 |
业务闭环内聚,跨模块复用需显式依赖 |
|
代码耦合度 |
层间耦合高(如Service依赖DAO) |
模块间通过接口解耦(依赖倒置) |
|
适用场景 |
简单单体应用 |
复杂业务系统或微服务架构 |
本项目基于Maven进行多模块开发,多模块项目是一种将大型项目拆分成多个小型、独立且相互协作的模块的开发方式。这种架构可以提高代码的可维护性、可扩展性和团队协作效率。
多模块项目的核心优势包括:
- 分而治之:将大项目拆分为多个模块,减少模块之间的耦合,提高可维护性。
- 独立开发:各模块可以独立开发和测试,便于团队协作。
- 重用性:模块可以在其他项目中复用,提高开发效率。
分模块结构图

2.1 创建父工程
在IDEA中创建maven项目,名称
pre_parent,父工程仅用于管理子工程依赖、插件配置、版本号等公共配置,不进行业务实现,因此src目录可以选择性删除,并在pom.xml中引入依赖,打包方式为: 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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.sy</groupId>
<artifactId>pre_parent</artifactId>
<version>1.0-SNAPSHOT</version>
<!--父工程的打包方式:pom-->
<packaging>pom</packaging>
<!--自动配置好子工程-->
<modules>
<module>pre_controller</module>
<module>pre_service</module>
<module>pre_mapper</module>
<module>pre_common</module>
<module>pre_pojo</module>
</modules>
<properties>
<maven.compiler.source>17</maven.compiler.source>
<maven.compiler.target>17</maven.compiler.target>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.6.13</version>
<relativePath/>
</parent>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--数据层-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.49</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.1.10</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.4</version>
</dependency>
<!--加入分页的依赖-->
<!--pagehelper-spring-boot-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper-spring-boot-starter</artifactId>
<version>1.4.2</version>
</dependency>
<!--工具类-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.76</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.20</version>
</dependency>
<!--热部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
</dependency>
</dependencies>
</project>
注意:
如果将依赖添加到父工程的pom中,根据依赖的继承关系,所有的子工程中都会继承父工程的依赖;
好处:当有多个子工程都需要相同的依赖时,无需在子工程中重复添加依赖
缺点:如果某些子工程不需要这个依赖,还是会被强行继承(即打包某一个子工程时,会进来很多无关的依赖)
如果在父工程中没有添加统一依赖,则每个子工程所需的依赖都要在对应的子工程的pom中手动添加。
2.2 创建实体类模块
创建
pre_pojo模块,用于存放实体类
2.3 创建工具类模块
创建
pre_common模块,用于存放通用的一些类,本模块需要依赖pre_pojo模块

2.4 创建持久层模块
创建
pre_mapper模块,用于存放持久层代码,本模块需要依赖pre_common模块

2.5 创建业务层模块
创建
pre_service模块,用于存放业务层代码,本模块需要依赖pre_mapper模块

2.6 创建表示层模块
创建
pre_controller模块用于存放管理后台的表示层代码,本模块需要依赖
pre_service模块

启动类

项目搭建结构目录

2.7 创建项目中需要的配置文件

2.8 导入sql文件到数据库

2.8.1 分析数据库中表结构

表结构关系
订单表与产品表的关系 多对多关系
订单表与会员表的关系 多对一关系
订单表与旅客表的关系 多对多关系
2.8.2 订单表信息描述 orders
|
序号 |
字段名称 |
字段类型 |
字段描述 |
|
1 |
id |
varchar(32) |
无意义、主键uuid |
|
2 |
orderNum |
varchar(50) |
订单编号 不为空 唯一 |
|
3 |
orderTime |
timestamp |
下单时间 |
|
4 |
peopleCount |
int |
出行人数 |
|
5 |
orderDesc |
varchar(500) |
订单描述(其它信息) |
|
6 |
payType |
int |
支付方式(0 支付宝 1 微信 2其它) |
|
7 |
orderStatus |
int |
订单状态(0 未支付 1 已支付) |
|
8 |
productId |
int |
产品id 外键 |
|
9 |
memberid |
int |
会员(联系人)id 外键 |
这种结构称之为数据字典。
2.8.3 会员表信息描述 member
订单与会员之间是多对一关系,我们在订单表中创建一个外键来进行关联。
|
序号 |
字段名称 |
字段类型 |
字段描述 |
|
1 |
id |
varchar(32) |
无意义、主键uuid |
|
2 |
name |
varchar(20) |
姓名 |
|
3 |
nickName |
varchar(20) |
昵称 |
|
4 |
phoneNum |
varchar(20) |
电话号码 |
|
5 |
|
varchar(50) |
邮箱 |
2.8.4 旅客表信息描述 traveller
订单表与旅客表关系 多对多关系
|
序号 |
字段名称 |
字段类型 |
字段描述 |
|
1 |
id |
varchar(32) |
无意义、主键uuid |
|
2 |
name |
varchar(20) |
姓名 |
|
3 |
sex |
varchar(20) |
性别 |
|
4 |
phoneNum |
varchar(20) |
电话号码 |
|
5 |
credentialsType |
int |
证件类型 0身份证 1护照 2军官证 |
|
6 |
credentialsNum |
varchar(50) |
证件号码 |
|
7 |
travellerType |
int |
旅客类型(人群) 0 成人 1 儿童 |
2.8.5 产品表信息描述 product
|
序号 |
字段名称 |
字段类型 |
字段描述 |
|
1 |
id |
varchar(32) |
无意义、主键uuid |
|
2 |
product_id |
varchar(50) |
产品编号,唯一,不为空 |
|
3 |
product_name |
varchar(50) |
产品名称(路线名) |
|
4 |
city_name |
varchar(50) |
出发城市 |
|
5 |
start_time |
timestamp |
出发时间 |
|
6 |
product_price |
Double |
产品价格 |
|
7 |
product_desc |
varchar(500) |
产品描述 |
|
8 |
product_status |
int |
状态(0关闭1开启) |
三、产品管理
3.1 查询所有产品功能
根据产品的名称模糊查询:要求分页

1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类


3、在pre_mapper中创建mapper接口和对应的mapper.xml文件


3.2 添加产品功能

1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类


3、在pre_mapper中创建mapper接口和对应的mapper.xml文件


3.3 开启和屏蔽状态

1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类


3、在pre_mapper中创建mapper接口和对应的mapper.xml文件


3.4 删除产品功能
删除可以实现单个产品删除, 也可以实现删除多个产品

1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类




3、在pre_mapper中创建mapper接口和对应的mapper.xml文件


3.5 回显产品信息
1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类


3、在pre_mapper中创建mapper接口和对应的mapper.xml文件


3.6 修改产品功能
1、在pre_controller中创建ProductController

2、在pre_service中创建ProductService接口和实现类


3、在pre_mapper中创建mapper接口和对应的mapper.xml文件



296

被折叠的 条评论
为什么被折叠?



