通过Express + Vue3从零构建一个用户认证与授权系统(一)项目结构设计

news/2024/10/11 19:46:27/

项目背景

本文基于 TypeScript + Express + Vue3 ,从零构建一个用户认证与授权管理系统。这个系统的核心部分包括前端、后端和数据库。我们需要确保各部分合理分层、易于维护和扩展,让我们一步步去实现我们的系统。

一、项目结构设计

1. 前端 (Vue 3 + Element Plus/Naive UI)
  • 使用 Vue 3 的单页面应用架构,配合 Vue Router 和 Vuex/Pinia 进行路由和状态管理。
  • UI 组件库选用 Element Plus/Naive UI来快速构建表单、表格、对话框等常用后台管理功能。

前端目录结构:

/frontend
├── public/                 # 静态资源
├── src/
│   ├── assets/             # 静态资源(图片、样式等)
│   ├── components/         # 公共组件
│   ├── layouts/            # 布局组件
│   ├── views/              # 各页面视图
│   ├── router/             # 路由配置
│   ├── store/              # 状态管理(Vuex/Pinia)
│   ├── services/           # 接口请求服务 (Axios等)
│   ├── utils/              # 工具函数
│   ├── App.vue             # 根组件
│   └── main.ts             # 入口文件
├── package.json
├── tsconfig.json           # TypeScript 配置
└── vite.config.js          # Vite 配置
2. 后端 (Node.js + Express + MySQL)
  • 使用 Node.js 和 Express 框架来搭建 RESTful API。
  • 数据库使用 MySQL,连接采用 Sequelize ORM 来管理模型和数据库交互。

后端目录结构:

/backend
├── src/
│   ├── config/             # 配置文件(数据库、swagger、logger等)
│   ├── controllers/        # 控制器 (处理业务逻辑)
│   ├── models/             # 数据库模型 (Sequelize)
│   ├── routes/             # 路由定义
│   ├── middlewares/        # 中间件(认证、错误处理等)
│   ├── types               # 自定义类型
│   ├── services/           # 业务逻辑层
│   ├── utils/              # 工具类
│   ├── app.ts              # Express 应用   
├── package.json
├── .env                    # 环境变量
└── nodemon.json            # nodemon配置
└── tsconfig.json           # ts配置

二、概要设计

1. 前端 (Vue 3 + Element Plus)
  • 用户管理页面:查看、添加、编辑和删除用户。
  • 权限管理页面:为不同角色设置不同权限。
  • 数据统计页面:展示关键业务数据的统计与分析图表。
  • 通知/消息中心:查看和管理系统消息通知。

使用 Vue Router 来管理路由,使用 Vuex/Pinia 来管理用户状态、权限和全局数据。采用 Axios 发起 HTTP 请求,和后端进行数据交互。

2. 后端 (Node.js + Express)
  • 用户管理 API:增删查改用户信息,支持分页和查询。
  • 登录/认证 API:使用 JWT 进行用户认证,支持权限控制。
  • 角色/权限管理 API:创建和管理角色,关联权限。
  • 数据统计 API:从数据库中获取业务相关数据,生成图表所需的数据。

使用 Sequelize 进行数据库操作,配合 MySQL。通过 Express 中间件实现身份验证、权限控制和错误处理。

三、接口设计

接口将采用 RESTful 风格,以下是一些基本的接口设计:

  • 用户管理 API

    • GET /api/users: 获取用户列表
    • GET /api/users/:id: 获取单个用户信息
    • POST /api/users: 创建新用户
    • PUT /api/users/:id: 更新用户信息
    • DELETE /api/users/:id: 删除用户
  • 角色/权限管理 API

    • GET /api/roles: 获取角色列表
    • POST /api/roles: 创建新角色
    • PUT /api/roles/:id: 更新角色
    • DELETE /api/roles/:id: 删除角色
    • GET /api/roles/:id/permissions: 获取角色的权限列表
  • 认证 API

    • POST /api/auth/login: 用户登录,返回 JWT Token
    • POST /api/auth/register: 用户注册
    • GET /api/auth/profile: 获取用户信息(需登录)
  • 数据统计 API

    • GET /api/stats/overview: 获取系统概览数据
    • GET /api/stats/:type: 根据类型获取统计数据

三、数据库设计

为了实现用户认证与授权,我们需要设计几个关键的数据库表:Users(用户表)、Roles(角色表)、Permissions(权限表)以及 RolePermissions(角色权限关联表)。

用户表 (Users)

用于存储用户的基本信息和认证数据。

字段名类型描述
idINTEGER主键,自增
usernameSTRING用户名,唯一
emailSTRING电子邮件,唯一
phoneSTRING电话号码,唯一
avatarSTRING头像 URL,可选
passwordSTRING加密后的密码
role_idINTEGER关联角色表的外键
createdAtDATE创建时间
updatedAtDATE更新时间

角色表 (Roles)

用于定义系统中的不同角色。

字段名类型描述
idINTEGER主键,自增
nameSTRING角色名称,唯一
descriptionSTRING角色描述,可选
createdAtDATE创建时间
updatedAtDATE更新时间

权限表 (Permissions)

用于定义系统中的不同权限。

字段名类型描述
idINTEGER主键,自增
nameSTRING权限名称,唯一
descriptionSTRING权限描述,可选
createdAtDATE创建时间
updatedAtDATE更新时间

角色权限关联表 (RolePermissions)

用于建立角色与权限之间的多对多关系。

字段名类型描述
roleIdINTEGER关联角色表的外键
permissionIdINTEGER关联权限表的外键
createdAtDATE创建时间
updatedAtDATE更新时间

四、开发框架技术栈

前端
  • Vue 3.0: 框架主流版本。
  • TypeScript:增强 JavaScript 的类型系统,提升代码的可读性和维护性。
  • Element Plus: UI组件库,后台系统常用,简化开发。
  • Axios: 异步请求库,方便与后端 API 交互。
后端
  • Node.js: 使用 Express 框架来搭建轻量级 API 服务。
  • TypeScript:增强 JavaScript 的类型系统,提升代码的可读性和维护性。
  • Sequelize: ORM 框架,简化与 MySQL 的数据交互。
  • JWT: JSON Web Token,用于实现用户认证和授权。
  • bcryptjs:用于密码加密。
  • Swagger:用于 API 文档的生成和展示。
  • dotenv:用于环境变量管理。
  • nodemon: 用于开发时自动重启服务器。
数据库
  • mysql: 用于与 MySQL 数据库通信。

总结

以上是用户权限管理系统的相关设计文档。下一篇开始搭建后端服务。


http://www.ppmy.cn/news/1537600.html

相关文章

fatal: urdf 中的 CRLF 将被 LF 替换

git add relaxed_ik_ros2 fatal: relaxed_ik_ros2/relaxed_ik_core/configs/urdfs/mobile_spot_arm.urdf 中的 CRLF 将被 LF 替换 这个错误信息表示 Git 在处理文件 mobile_spot_arm.urdf 时发现它使用了 CRLF(回车换行符,常见于 Windows 系统&#xff0…

[Meachines] [Easy] Sea WonderCMS-XSS-RCE+System Monitor 命令注入

信息收集 IP AddressOpening Ports10.10.11.28TCP:22,80 $ nmap -p- 10.10.11.28 --min-rate 1000 -sC -sV PORT STATE SERVICE VERSION 22/tcp open ssh OpenSSH 8.2p1 Ubuntu 4ubuntu0.11 (Ubuntu Linux; protocol 2.0) | ssh-hostkey: | 3072 e3:54:…

C语言复习第0章 基础语法

目录 一、概述及前置知识1.1 什么是集成开发环境1.2 main函数1.3 单位1.4 注释1.5 函数简介1.6 C语言中真和假的概念1.7 C语言的内存分区1.8 EOF-文件结束标志1.9 头文件一般放什么内容 二、数据类型2.1 八大类型的大小2.2 默认浮点数为double类型2.3 占位符(????????)…

单点登录Apereo CAS 7.1客户端集成教程

从上一篇部署并成功运行CAS服务端后,我们已经能通过默认的账号密码进行登录。 上篇地址:单点登录Apereo CAS 7.1安装配置教程-CSDN博客 本篇我们将开始对客户端进行集成。 CAS中的客户端,就是指我们实际开发的各个需要登录认证的应用。现在,跟着笔者的步伐,一起探索如何…

【浏览器】HTTP 状态码

HTTP 状态码 HTTP 状态码用于表示服务器对请求的响应状态,分为 5 类,每一类的状态码代表不同的响应类型: 1. 1xx 信息性响应 表示请求已接收,服务器继续处理。 100 Continue:客户端应继续请求操作,服务…

【数学分析笔记】第5章第1节 微分中值定理(1)

5. 微分中值定理及其应用 5.1 微分中值定理 5.1.1 极值与极值点 【定义5.1.1】 f ( x ) f(x) f(x)定义域为 ( a , b ) (a,b) (a,b), x 0 ∈ ( a , b ) x_0\in(a,b) x0​∈(a,b),若 ∃ O ( x 0 , ρ ) ⊂ ( a , b ) \exists O(x_0,\rho)\subset(a,b) ∃…

本地生活服务项目入局方案解析!本地生活服务商系统能实现怎样的作业效果?

当前,各大平台的本地生活服务业务日渐兴盛,提高创业者入局意向的同时,也让本地生活服务项目有哪些等问题也成为了多个创业者社群中的热议对象。而从目前的讨论情况来看,在创业者们所询问的众多本地生活服务项目中,通过…

宠物咖啡馆平台开发:SpringBoot技术的综合应用

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…