一、项目初始化
- 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;
-- 创建用户表
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)
)
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热更新官方文档