一、项目初始化

  • 1、下载原代码及安装依赖包

  • 2、根目录下创建一个.env的文件

    // 端口号
    PORT = 4000;
    
    // mysql数据库配置
    DB_TYPE = mysql;
    DB_HOST = localhost;
    DB_USERNAME = root;
    DB_PASSWORD = root;
    DB_DATABASE = test;
    DB_PORT = 3306;
    DB_SYNCHRONIZE = false;
    DB_LOGGING = true;
    
    // jwt加盐
    SECRET = abc;
    // 前缀
    PREFIX = api / v1;
    
  • 3、创建数据库及创建表

    -- 创建用户表
    CREATE TABLE `user`(
      id int(11) PRIMARY KEY auto_increment COMMENT '主键id',
      uuid VARCHAR(150) UNIQUE NOT NULL COMMENT 'uuid主键',
      name VARCHAR(100) UNIQUE NOT NULL COMMENT '姓名',
      password VARCHAR(255) NOT NULL COMMENT '密码',
      email VARCHAR(100) COMMENT '邮箱',
      mobile VARCHAR(11) COMMENT '手机号码',
      gender TINYINT DEFAULT 0 COMMENT '性别',
      create_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
      update_at TIMESTAMP ON UPDATE CURRENT_TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间'
    )
    
    -- 创建角色表
    CREATE TABLE `role`(
      id int(11) PRIMARY KEY auto_increment comment '主键id',
      name varchar(10) UNIQUE not null comment '角色名称',
      create_at timestamp default current_timestamp comment '创建时间',
      update_at timestamp on update current_timestamp default current_timestamp comment '更新时间'
    )
    
    -- 创建用户与角色的关联表
    create table `role_user`(
      role_id int(11) comment '角色id',
      user_id int(11) comment '用户id',
      PRIMARY key(role_id, user_id)
    )
    
    -- 创建资源表
    create table `resource`(
      id int(11) primary key auto_increment comment '主键id',
      uuid VARCHAR(150) UNIQUE NOT NULL COMMENT 'uuid主键',
      name VARCHAR(100) UNIQUE NOT NULL COMMENT '资源名称',
      parent_id int(11) not null default 0 comment '父资源id',
      create_at timestamp default current_timestamp comment '创建时间',
      update_at timestamp on update current_timestamp default current_timestamp comment '更新时间'
    )
    
    -- 创建资源和角色的关联表
    create table `role_resource`(
      role_id int(11) comment '角色id',
      resource_id int(11) comment '资源id',
      primary key(role_id, resource_id)
    )
    
  • 4、运行代码

    npm run start:dev
    # or
    npm run webpack
    npm run start1
    

二、主要实现功能

  • 使用nestjs-configdotenv保存敏感数据及在项目中直接使用ConfigService参考文档
  • 使用typeorm-model-generator由数据库表迁移生成*.entity.ts文件参考我的文章
  • 使用node-auth0模块进行密码加密处理(见src/core/user/user.entity.ts)
  • 使用jwt对用户登录授权(见src/shared/guard/auth.guard.ts)
  • 封装了统一成功、失败数据返回格式,并在全局使用(见src/shared/interceptor/transform.interceptor.tssrc/shared/filters/http-exception.filter.ts)
  • 封装了用户提交数据错误提示(见src/shared/pipe/validation.pipe.ts)
  • 日志拦截器,用于记录各个请求访问时间(见src/shared/interceptor/logging.interceptor.ts)
  • 核心模块curl封装了httpModule模块的网络请求
  • 使用@nestjs/swagger swagger-ui-express生成API文档(见src/main.ts)
  • 安全方面
  • src/core中添加上传附近模块官网地址
  • 使用webpack热更新官方文档

三、项目链接地址