当前位置: 首页 > news >正文

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

项目背景

本文基于 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 数据库通信。

总结

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

相关文章:

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

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

JavaScript 第13章:Ajax 与异步请求

在Web开发中,异步请求是一种非常重要的技术,它可以让网页在不重新加载的情况下与服务器交互。本章将介绍两种常用的异步请求技术:XMLHttpRequest 和 Fetch API,以及它们如何用于处理JSON数据交换,并通过一个实战案例—…...

速卖通商品详情接口技术解析及Python代码示例

速卖通商品详情接口技术解析及Python代码示例 速卖通(AliExpress)作为全球知名的跨境电商平台,其开放平台提供了丰富的API接口,允许开发者集成速卖通的各项功能,实现商品搜索、详情查询、订单管理等一系列操作。本文将…...

邻接表的有向网(C语言代码)

#include <stdio.h> #include <stdlib.h> #define MVNum 100 //最大顶点数 //边表结构体 typedef struct ArcNode { //表结点 int adjvex; //邻接点的位置 struct ArcNode* nextarc; //指向下一个…...

大模型生成PPT大纲优化方案:基于 nVidia NIM 平台的递归结构化生成

大模型生成PPT大纲优化方案&#xff1a;基于 nVidia NIM 平台的递归结构化生成 待解决的问题 生成PPT大纲是一种大模型在办公场景下应用的常见需求。 然而&#xff1a; 目前直接让大模型生成大纲往往是非结构化的&#xff0c;输出格式多样&#xff0c;难以统一和规范&#…...

MRSO算法(JCR2区)

原论文摘要&#xff1a;智能技术的快速发展促使利用自然行为来解决复杂问题的优化算法得以发展。其中&#xff0c;鼠群优化算法&#xff08;Rat Swarm Optimizer&#xff0c;RSO&#xff09;受老鼠的社会和行为特征启发&#xff0c;在各个领域已展现出潜力&#xff0c;但其收敛…...

最新Spring Boot3框架入门教程,基础知识讲解(参考官方文档),同时基于MybatisPlus+MYSQL搭建后台管理系统基础流程(附源码)

本文所涉及的代码以及相关文件均上传至仓库:GitHub - yang66-hash/XDPropertyManagementSystemDemo: This is a demo template based on SpringBoot3 in the background of property management system. Spring Boot 是由 Pivotal 团队开发的一款开源框架&#xff0c;它可以帮助…...

导数的概念及在模型算法中的应用

一. 导数概念与计算 1. 导数的物理意义&#xff1a; 瞬时速率。一般的&#xff0c;函数yf(x)在x处的瞬时变化率是 2. 导数的几何意义&#xff1a; 曲线的切线&#xff0c;当点趋近于P时&#xff0c;直线 PT 与曲线相切。容易知道&#xff0c;割线的斜率是当点趋近于 P 时&…...

获取首日涨停封盘后第二次交易日上涨/下跌的概率

有许多投资者喜欢在股票涨停封盘后&#xff0c;跟进买入。普通股民会认为一个能在今日涨停封盘的股票&#xff0c;证明其上市公司正有十分重大的利好信息&#xff0c;只需要跟进购买便可以获取短期利益。 我们用数据来看一下在当日涨停封盘后&#xff0c;第二次交易日是上涨还…...

shell $ 用法

Shell脚本中$符号的几种用法小结_linux shell_脚本之家 Shell 传递参数 | 菜鸟教程 $ 符号说明$0Shell 的命令本身1到9表示 Shell 的第几个参数$?显示最后命令的执行情况$#传递到脚本的参数个数$$脚本运行的当前进程 ID 号$*以一个单字符串显示所有向脚本传递的参数$!后台运行…...

如何用支付宝实现靠脸吃饭

还记得上学时&#xff0c;每当下课铃声响起&#xff0c;我们就会像一群脱缰的野马一样&#xff0c;浩浩荡荡地冲向食堂。最令人崩溃的时刻莫过于终于到达打饭窗口前排时&#xff0c;却发现饭卡忘带了&#xff01;但现在&#xff0c;这种情况将不再发生。许多学校食堂已经配备了…...

Visual Studio的实用调试技巧总结

对于很多学习编程的老铁们来说&#xff0c;是不是也像下面这张图一样写代码呢&#xff1f; 那当我们这样编写代码的时候遇到了问题&#xff1f;大家又是怎么排查问题的呢&#xff1f;是不是也像下面这张图一样&#xff0c;毫无目的的一遍遍尝试呢&#xff1f; 这篇文章我就以 V…...

graphrag学习总结

学习视频&#xff1a;b站链接 项目链接 GraphRAG 的基本概念 Document&#xff08;文档&#xff09;&#xff1a;系统中的输入文档。这些文档要么代表CSV中的单独行&#xff0c;要么代表单独的txt文件。 TextUnit&#xff08;文本块&#xff09;&#xff1a;要分析的文本块。…...

专题:贪心算法(已完结)

1.分发饼干 方法一&#xff1a;用最大的胃口 找到最大的饼干&#xff08;先遍历胃口&#xff09; class Solution { public:int findContentChildren(vector<int>& g, vector<int>& s) {// 主要思路 用最大的饼干找最大的胃口sort(g.begin(),g.end());so…...

Hadoop的三种运行模式:单机模式、伪分布式模式和完全分布式模式

单机模式 单机模式是Hadoop最简单的运行模式。在单机模式下&#xff0c;所有Hadoop组件都运行在单个机器上&#xff0c;包括HDFS、MapReduce等。由于只有一个节点参与计算&#xff0c;单机模式适用于开发和测试阶段&#xff0c;不适合用于处理大规模数据。在单机模式下&#xf…...

JavaScript将array数据下载到Excel中

具体代码如下&#xff1a; <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widt…...

【前端】Bootstrap:快速开始

Bootstrap 是一个功能强大且易于使用的前端框架&#xff0c;专门用于创建响应式和移动优先的网页。学习Bootstrap不仅可以帮助你快速构建现代网页&#xff0c;还可以提升你对前端开发流程的理解。本教程将从基础概念开始&#xff0c;逐步引导你掌握Bootstrap&#xff0c;并通过…...

文献阅读(222) VVQ协议死锁

题目&#xff1a;VVQ: Virtualizing Virtual Channel for Cost-Efficient Protocol Deadlock Avoidance时间&#xff1a;2023会议&#xff1a;HPCA研究机构&#xff1a;KAIST request-reply协议死锁如下图所示&#xff0c;每个node收到request之后发送reply&#xff0c;但是想…...

Node.js管理工具NVM

nvm&#xff08;Node Version Manager&#xff09;是一个用于管理多个 Node.js 版本的工具。以下是 nvm 的使用方法和一些常见命令&#xff1a; 一、安装 nvm 下载 nvm&#xff1a; 地址&#xff1a;https://github.com/coreybutler/nvm-windows/releases访问 nvm 的 GitHub 仓…...

云原生后端

云原生后端&#xff08;Cloud-Native Backend&#xff09;是指在云计算环境中&#xff0c;利用云原生技术&#xff08;如容器、微服务、服务网格等&#xff09;构建和部署后端应用程序的一种方法。以下是对云原生后端的详细讲解&#xff1a; 1. 定义 云原生是一种设计和构建应…...

郭老师-帝王霸鬼四道:为何只能正学,不可反学

帝王霸鬼四道 ——为何只能正学&#xff0c;不可反学&#xff1f;“让三岁娃背《孙子兵法》&#xff1f; 不是启蒙&#xff0c; 而是—— 把刀交给婴儿。”&#x1f33f; 真正的根基&#xff0c;不在谋略&#xff0c; 而在—— 《大学》《中庸》《系辞传》&#x1f9ed; 一、四…...

难点突破:HR 每天看 200 份简历,80% 时间都在做无效劳动

去年某互联网公司招一个产品经理&#xff0c;收到 847 份简历。HR 小王花了整整三天时间初筛&#xff0c;最后发现真正符合要求的只有 23 个人。更让人崩溃的是&#xff0c;这 23 个人里有 5 个是第二天才看到的——因为简历太多&#xff0c;优质候选人被淹没在简历海里。 这不…...

虚幻引擎+数字孪生:手把手搭建智慧校园三维可视化平台(附浙江工商大学实战案例)

虚幻引擎数字孪生&#xff1a;从零构建智慧校园三维可视化平台的完整指南 想象一下&#xff0c;清晨走进校园时&#xff0c;管理员已经在三维可视化平台上完成了安防巡查&#xff1b;教务主任通过热力图调整着今天的课程安排&#xff1b;后勤人员正根据实时数据优化能源分配——…...

STM32摇杆驱动设计:裸机与FreeRTOS下的轻量级Joystick模块实现

1. 项目概述“Joystick”并非一个通用型开源驱动库或标准化外设抽象层&#xff0c;而是一个面向特定毕业设计&#xff08;Tesis&#xff09;场景的嵌入式人机交互模块实现。其核心目标是为基于STM32系列微控制器&#xff08;如STM32F407VG、STM32F103C8T6等常见开发板&#xff…...

零宽度字符隐写术全解析:从Unicode原理到实战检测工具推荐

零宽度字符隐写术全解析&#xff1a;从Unicode原理到实战检测工具推荐 在数字信息安全的隐秘角落&#xff0c;有一种几乎不可见的通信方式正在被安全研究人员和渗透测试工程师频繁使用——零宽度字符隐写术。这种技术允许我们将秘密信息嵌入普通文本中&#xff0c;肉眼无法察觉…...

抖音直播智能采集与实时分析实战指南:从数据捕获到商业决策

抖音直播智能采集与实时分析实战指南&#xff1a;从数据捕获到商业决策 【免费下载链接】DouyinLiveWebFetcher 抖音直播间网页版的弹幕数据抓取&#xff08;2024最新版本&#xff09; 项目地址: https://gitcode.com/gh_mirrors/do/DouyinLiveWebFetcher 在数字营销与内…...

SAP EWM RF手持设备开发实战:从SPRO配置到屏幕绘制的完整流程

SAP EWM RF手持设备开发实战&#xff1a;从SPRO配置到屏幕绘制的完整流程 在仓储物流领域&#xff0c;SAP EWM&#xff08;Extended Warehouse Management&#xff09;系统的RF&#xff08;Radio Frequency&#xff09;手持设备开发一直是技术难点与业务痛点的交汇处。不同于传…...

AnimateDiff保姆级教学:负面提示词详解,轻松提升视频画质

AnimateDiff保姆级教学&#xff1a;负面提示词详解&#xff0c;轻松提升视频画质 你是否遇到过这样的困扰&#xff1a;用AnimateDiff生成的视频创意很棒&#xff0c;但画面总有些小瑕疵&#xff1f;比如人物皮肤上不自然的纹理、背景里莫名其妙的噪点&#xff0c;或是某些区域…...

STM32磁悬浮平衡术(一):PID算法调校与硬件选型指南

1. PID算法&#xff1a;磁悬浮系统的"大脑" 磁悬浮系统的核心挑战在于如何让浮子稳定悬浮。想象一下&#xff0c;你要用手指顶着一根铅笔保持直立——这需要不断微调手指的位置来抵消铅笔的倾斜。PID算法就是STM32中扮演这个"微调手指"角色的关键程序。 PI…...

earthengine-api 未来展望:路线图、新功能和社区发展趋势

earthengine-api 未来展望&#xff1a;路线图、新功能和社区发展趋势 【免费下载链接】earthengine-api Python and JavaScript bindings for calling the Earth Engine API. 项目地址: https://gitcode.com/gh_mirrors/ea/earthengine-api earthengine-api 作为连接地球…...