NestJS 企业级应用开发:基于 MongoDB 和 JWT 的 RESTful API 模板
基于 nestjs mongoose jwt 的 restful 模板程序 用于快速搭建服务端程序
涉及技术框架
- nestjs 服务框架
- mongoose 操作数据库的库
- typegoose 使用类定义数据模型
- nestjs-typegoose
- mongoose-paginate 分页插件
- jwt 生成验证 token
- swagger 文档生成
配置文件
nestjs-config 管理配置文件
1 | /env/ |
Redis 缓存基本用法
1 | // controller |
功能
- 用户登陆注册
- jwt 验证
- 增删改查,分页查询
- 统一异常处理(使用业务状态码)
- 统一返回结构
- 自定义 user 装饰器 src/common/decorator/user.decorator
- mongo objectid 示例管道
- 跨域处理
- 文件上传示例(转存到云服务)
- redis 缓存
- 异常发送邮件提醒
- 权限角色管理
- 自动生成代码
Installation
$ npm install
Running the app
1 | # development |
Test
1 | # unit tests |
文档地址
异常处理
异常过滤器
- src\common\filters\http-exception.filter.ts
自定义 api 异常
- src\common\exceptions\api.exception.ts
拦截器
- src\common\interceptor\exception.interceptor.ts
- src\common\interceptor\transform.interceptor.ts
异常使用方式
1 | throw new ApiException("ID无效", ApiErrorCode.ID_INVALID, HttpStatus.BAD_REQUEST); |
接口文档 (yapi)
使用 yapi import 工具 导入 swagger 文档到 yapi 中 配置yapi-import.json
1 | npm run yapi |
api 代码生成(yapi-gen-js-code)
使用 yapi-gen-js-code 进行 yapi 的代码生成 进行了一些调整修改,以适配当前前端代码 使用配置yapi-import.json
1 | npm run gapi |
生成的代码只需要把需要的部分复制到前端相应的文件中
权限角色思路
使用putApi2DB.js
把 ypi 上的接口全都插入到数据库中。单独修改里面的配置
1 | node .\putApi2DB.js |
Getting started
需要先创建公司,分配公司管理员权限(务必把角色和用户管理权限分配给管理员,否则公司管理员无法自行管理用户角色)。使用 db.js 已配置
- 先把 db.js 导入到数据库 后台管理用户名密码 houxiaozhao/houxiaozhao
- 测试公司用户名密码 18300000000/18300000000
rest 接口使用方式
CRUD 生成器
1
nest g resource modules/device --no-spec
Model Service Controller DTO 修改
yapi(可选)
- 接口文档同步到 yapi
1
npm run yapi
- 生成前端代码
1
npm run gapi
把 api 接口加到数据库中(可选)
- 添加 api(设置为需要验证)
- 设置权限
- 设置角色
- 添加菜单
- 添加按钮(可选,权限设置)
登录管理后台,创建 api,创建菜单,创建设备管理权限
登录用户前端,角色管理,创建设备管理角色,为用户分配设备管理角色,然后刷新即可显示出设备管理菜单(现在点击菜单显示 404)
切换到前端代码 web
创建页面设备管理页面(device/index.vue)
创建路由(和第 5 步创建菜单的路径一致)
复制 views/demo/page1/index.vue 的代码到 device/index.vue,修改 name 和路由一致
在/src/api/modules 文件夹创建 device.api.js
1
2
3export default ({ service, request, serviceForMock, requestForMock, mock, faker, tools }) => ({
// 自动生成代码
});复制自动生成的关于设备管理代码到/src/api/modules/device.api.js
修改/device/index.vue 里的增删改查函数名称
根据需要修改字段
- addDataForm
- editDataForm
- addRules
- editRules
- addData 函数定义添加字段
- editData 函数定义编辑字段
- 表格显示字段
- 添加表单
- 编辑表单
如果配置了按钮权限(能不能添加、编辑、删除等),需要使用
buttonid
指令 xxx 为数据库按钮的 id1
v-buttonid="'xxx'"