對於後端管理系統,存取控制和個人化使用者介面等功能至關重要。例如,超級管理員可以查看所有頁面,一般使用者可以造訪A、B頁面,VIP使用者可以查看A、B、C、D頁面。這些功能背後的邏輯是基於三個關鍵概念的設計:
關係可以用下圖來說明:
接下來,我們將使用Nest從頭開始實現這樣一個系統的基礎-權限設計。
首先,我們需要建立資料庫。我們將使用 MySQL 資料庫並執行以下命令來建立它:
CREATE DATABASE `nest-database` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
我們將透過執行以下命令啟動一個新的 Nest 專案:
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 {}
通常,RBAC(基於角色的存取控制)系統將有 5 個表,如下所示:
領域模型可以視覺化如下:
接下來,我們將在 Nest 中建立三個非關係表並定義它們的關係。
CREATE DATABASE `nest-database` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;
在User表中,定義了roles欄位來連接user_role_relation表。關係邏輯為:user.id === userRoleRelation.userId 和 role.id === userRoleRelation.roleId。匹配的角色記錄會自動連結到使用者。
nest new nest-project
角色表中的權限欄位的工作原理類似。它使用以下邏輯與 role_permission_relation 表連接: role.id === rolePermissionRelation.roleId 和permission.id === rolePermissionRelation.permissionId。
npm install --save @nestjs/typeorm typeorm mysql2
權限表沒有關係;它只是記錄可用的權限。
這是一個用來初始化一些測試資料的服務:
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 {}
透過瀏覽器或Postman執行initData服務,資料將填入資料庫。
設定基本權限結構後,您現在可以實現註冊、登入和基於 JWT 的身份驗證等功能。
現在輪到你了!
Leapcell 是用於 Web 託管、非同步任務和 Redis 的下一代無伺服器平台:
多語言支援
免費部署無限個專案
無與倫比的成本效率
簡化的開發者體驗
輕鬆的可擴充性和高效能
在文件中探索更多內容!
在 X 上追蹤我們:@LeapcellHQ
閱讀我們的部落格
以上是使用 Nest.js 設計 RBAC 權限系統:逐步指南的詳細內容。更多資訊請關注PHP中文網其他相關文章!