
构建基于角色的访问控制 (RBAC) 系统:NestJS 实现
后端管理系统需要强大的访问控制和个性化界面。例如,超级管理员拥有所有权限,普通用户只能访问部分页面,VIP 用户则拥有更多权限。这需要一个基于用户、角色和权限的访问控制系统。
核心概念:
- 用户: 系统的基本单位,例如 Alice、Bob、Charlie。
- 角色: 用户可以拥有一个或多个角色,例如,Alice 同时拥有普通用户和 VIP 角色。
- 权限: 角色关联多个权限,例如,VIP 角色可能拥有查看、编辑和添加权限,而超级管理员拥有所有权限(查看、编辑、添加和删除)。
关系图如下:

本文将使用 NestJS 框架构建一个 RBAC 系统的基础——权限设计。
数据库设置:
使用 MySQL 数据库,创建数据库:
CREATE DATABASE `nest-database` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
项目初始化及依赖安装:
创建新的 NestJS 项目:
nest new nest-project
安装 TypeORM 和 MySQL2 依赖:
npm install --save @nestjs/typeorm typeorm mysql2
在 app.module.ts 中配置 TypeORM:
import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { TypeOrmModule } from '@nestjs/typeorm';
@Module({
imports: [
TypeOrmModule.forRoot({
type: 'mysql',
host: 'localhost',
port: 3306,
username: 'root',
password: 'password',
database: 'nest-database',
synchronize: true,
logging: true,
entities: [__dirname + '/**/*.entity{.ts,.js}'],
poolSize: 10,
connectorPackage: 'mysql2',
}),
],
controllers: [AppController],
providers: [AppService],
})
export class AppModule {}
数据库表设计:
mallcloud商城基于SpringBoot2.x、SpringCloud和SpringCloudAlibaba并采用前后端分离vue的企业级微服务敏捷开发系统架构。并引入组件化的思想实现高内聚低耦合,项目代码简洁注释丰富上手容易,适合学习和企业中使用。真正实现了基于RBAC、jwt和oauth2的无状态统一权限认证的解决方案,面向互联网设计同时适合B端和C端用户,支持CI/CD多环境部署,并提
典型的 RBAC 系统包含以下五个表:
- 用户表 (users): 存储用户信息,如用户名、密码、邮箱等。
- 角色表 (roles): 存储角色信息,如角色名称、角色代码等。
- 权限表 (permissions): 存储权限信息,如权限名称、权限代码等。
- 用户角色关系表 (user_role_relation): 跟踪用户和角色之间的多对多关系。
- 角色权限关系表 (role_permission_relation): 跟踪角色和权限之间的多对多关系。
实体关系图:

接下来,我们将创建三个实体类 (User, Role, Permission) 并定义它们的关系。
实体类定义:
user.entity.ts:
// ... (import statements)
@Entity()
export class User {
// ... (fields and relationships)
}
role.entity.ts:
// ... (import statements)
@Entity()
export class Role {
// ... (fields and relationships)
}
permission.entity.ts:
// ... (import statements)
@Entity()
export class Permission {
// ... (fields)
}
(完整的实体类代码与原文相同,此处省略以节省空间。)
数据初始化:
创建一个服务用于初始化测试数据 (代码与原文相同,此处省略)。

完成以上步骤后,您已经构建了 RBAC 系统的基础权限结构。 接下来可以实现用户注册、登录以及基于 JWT 的身份验证等功能。

(Leapcell 广告部分与原文相同,此处省略)









