一、项目初始化
-
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-config
和dotenv
保存敏感数据及在项目中直接使用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.ts
和src/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
热更新官方文档