一、为什么用yapi

  • yapi基于文档注释生成,没有代码的入侵。
  • 同一个工程的接口文档可以导出多个项目中,分权限查看。
  • 可以本地化部署,统一的接口文档,支持其他的文档接入。
  • 有idea插件支持,自动导出。

二、安装部署

  1. 安装

    这里只是记录个人操作过程,详情可看官网,连接在这里

    注意:要先配置好再启动,启动后超管默认的密码在启动日志里面。配置文档/data/yapi/vendors/config.json参考以下:
{
"port": "16888",
"adminAccount": "xxx@xx.com",
"closeRegister":true,
"timeout":120000,
"db": {
"servername": "127.*.*.*",
"DATABASE": "yapi",
"port": 1666,
"user": "yapi111",
"pass": "yapi111",
"authSource": ""
},
"mail": {
"enable": false,
"host": "smtp.163.com",
"port": 465,
"from": "***@163.com",
"auth": {
"user": "***@163.com",
"pass": "*****"
}
}
}

部署过程如下:

mkdir /data/yapi
cd /data/yapi
git clone https://github.com/YMFE/yapi.git vendors //或者下载 zip 包解压到 vendors 目录(clone 整个仓库大概 140+ M,可以通过 `git clone --depth=1 https://github.com/YMFE/yapi.git vendors` 命令减少,大概 10+ M)
cp vendors/config_example.json ./config.json //复制完成后请修改相关配置
cd vendors
npm install --production --registry https://registry.npm.taobao.org
npm run install-server //安装程序会初始化数据库索引和管理员账号,管理员账号名可在 config.json 配置
node server/app.js //启动服务器后,请访问 127.0.0.1:{config.json配置的端口},初次运行会有个编译的过程,请耐心等候
  1. 后台运行

    目前只做了nohup启动,后期可做成服务,加入到系统自启动中。
cd /data/yapi/vendors
nohup node server/app.js > runoob.log 2>&1 &
  1. 账号添加

    方式一:开放首页注册功能,默认是开启的。

    方式二:关闭注册功能,从数据中添加。可通过配置文件修改"closeRegister":true关闭注册功能,通过以下代码实现添加。
#角色类型,目前了解到两种,其他以后补充
guest #访客
admin #超级管理员 #获取用户
db.getCollection("user").find({}) #修改用户角色
db.user.update({"_id":2}, {$set: {"role":"admin"}});
db.user.update({"_id":20}, {$set: {"role":"guest"}}); #添加用户
db.user.insert({
"_id" : NumberInt(22),
"study" : true,
"type" : "site",
"username" : "test",
"password" : "b24bfd3584d83d82192239ace3bef9b7489136ad", #12345678
"email" : "test@qq.com",
"passsalt" : "j9bklcsuq6",
"role" : "guest",
"add_time" : NumberInt(new Date().getTime() /1000),
"up_time" : NumberInt(new Date().getTime() /1000),
"__v" : NumberInt(0)
});

三、idea中使用。

我使用的插件是EasyYapi,这里就不详细介绍插件的使用了。如果我们要个性话的配置文档的输出,可以在工程根目录加上文件.easy.api.config,在文件中就可以个性话定制输出了,eg: field.ignore=#ignore

以下主要记录下项目运用中的主要关注点:

  1. 使用@module app,可以很方便的将文档输出到指定的项目。
/**
* 首页接口
*
* @module app
* @Author xxx
* @Date 2022/12/6 11:26
* @description
*/
  1. 使用@ignore,可以忽略不输出到文档中。
    /**
* 条件转换
*
* @ignore
*/
String transform;
  1. 很多时候接口都是需要登录设置token的,方便后续的接口调用。



    代码如下:
context.requestHeader.Authorization = storage.getItem('token');

if (context.responseData && context.responseData.data && context.responseData.data.token) {
storage.setItem("token", context.responseData.data.token)
}

记一次yapi部署过程的更多相关文章

  1. 记一次sentry部署过程

    本文记录下部署sentry和其中遇到的问题 Sentry 是一款基于 Django实现的错误日志收集和聚合的平台,它是 Python 实现的,但是其日志监控功能却不局限于python,对诸如 Node ...

  2. Tomcat_记一次tomcatwar包应用简单部署过程

    记一次tomcat war包应用简单部署过程 by:授客 QQ:1033553122 1.  实践环境 Linux apache-tomcat-7.0.73 2.  实践步骤 # 解压tomcat压缩 ...

  3. 记一次OutOfMemory定位过程-续

    在前文<记一次OutOfMemory定位过程>完成时最终也没有定位到ECS 中JVM Heap size无法控制的原因,今天再次尝试终于有了一些线索,翻查了ECS的部署脚本发现了memor ...

  4. hudson部署过程

    hudson部署过程: java安装 http://developer.51cto.com/art/201504/470683.htm tomcat安装 http://blog.csdn.net/hu ...

  5. SCCM 2012 R2安装部署过程和问题(三)

    上篇 SCCM 2012 R2安装部署过程和问题(二) 个人认为对于使用SCCM 2012的最重要的经验是耐心. SCCM采用分布式部署的架构,不同的站点角色可以部署在不同的服务器上,站点角色之间的通 ...

  6. SCCM 2012 R2安装部署过程和问题(二)

    上篇:SCCM 2012 R2安装部署过程和问题(一) 在上篇我们已经完成了SCCM 2012 R2安装前的准备,其中有许多细节,关于数据库的准备和权限的设置是需要特别注意的.那么接下来我们开始安装S ...

  7. SCCM 2012 R2安装部署过程和问题(一)

    在进行Windows Server 2012 R2虚拟化测试前,由于需要安装,部署和管理很多的服务器,自然会想到该如何提高效率和有效的管理.在Windows Server 2008的时代微软已经提供称 ...

  8. BeX5平台简明部署过程

    http://wex5.com/cn/concise-deployment/ BeX5平台简明部署过程 该文章主要介绍BeX5平台开发完成后,资源部署至正式环境的过程. 一. 获取BeX5企业快速开发 ...

  9. 淘宝分布式 key/value 存储引擎Tair安装部署过程及Javaclient測试一例

    文件夹 1. 简单介绍 2. 安装步骤及问题小记 3. 部署配置 4. Javaclient測试 5. 參考资料 声明 1. 以下的安装部署基于Linux系统环境:centos 6(64位),其他Li ...

  10. windows server 2008 R2 Enterprise 间实时同步之FreeFileSync 部署过程

    WindowsServer间实时同步之FreeFileSync 部署过程 1. 实验主机信息 IP 操作系统 源目录 目标目录 10.155.0.80 Windows Server 2008 R2 D ...

随机推荐

  1. fastapi loguru

    使用loguru记录日志 安装 pip install loguru 基本使用 那么这个库怎么来用呢?我们先用一个实例感受下: In [1]: from loguru import logger .. ...

  2. el-form不进行校验可能的原因

    可能原因 el-form至少需要:model="你的数据form",:rules='你的校验规则' 的属性: 只能校验el-input,不能对原始input进行校验 (大坑).

  3. C++杂乱

    基本内置类型 类型 关键字 布尔型 bool 字符型 char 整型 int 浮点型 float 双浮点型 double 无类型 void 宽字符型 wchar_t endl是换行符 cout < ...

  4. DDD(三)DDD实战、贫血模型与充血模型

    DDD(三)DDD实战.贫血模型与充血模型 如果觉得样式不好:跳转即可 http://www.lifengying.site/(md文件复制过来有些样式会不一样) 贫血模型与充血模型 1.贫血模型:一 ...

  5. 使用vite创建vue3+ts项目完整流程

    1.创建项目 npm init vite@latest 依次输入项目名称.选择vue.选择ts 2.引入依赖 cd 项目名称 npm install 3.启动项目 npm run dev 4.引入vu ...

  6. S家lic

    1,用1patch里对应的工具patch 2019的s家的工具2,用ocad里的lmgrd和snpslmd替换s家的scl里的3,用scl_keygen产生license,再用fix.bat,添加si ...

  7. 解决通过Eclipse启动Tomcat-Run On Server无法选择Tomcat v7.0的问题

    在eclipse中配置Tomcat并启动右键项目 -> Run As -> Run on Server可能会出现无法选择Tomcat v7.0的现象如下图,不慌菜鸟小编带你解决!1.定位到 ...

  8. react常见bug - 查询条件变化,但page未重置为1

    问题1.多次触发请求,且存在潜在的竞态问题 const [page, setPage] = useState(1); const [keyword, setKeyword] = useState('' ...

  9. react实现某个元素节点截图(html2canvas)

    1.安装所需插件:html2canvas: 2.引入插件: import html2canvas from 'html2canvas'; 3.使用: const creatImg = () => ...

  10. scala概述入门和项目创建

    1.scala简介 (1).scala基于JVM,与JAVA完全兼容,具有跨平台.可移植性好.方便的垃圾回收等特性: (2).scala比JAVA更加面向对象: (3).scala是一门函数式编程语言 ...