【Linux】搭建Yapi接口管理工具(yapi接口测试的流程和步骤)
myzbx 2025-03-29 19:55 16 浏览
在年前员工访谈时发现,前后端协作开发会出现一定的内耗现象,在当前前后端分离的情况下前端往往会因为后端接口存在问题影响对接速度,在接口设计不明确的情况下还需要反复确认和沟通。公司过往使用ApiManager做接口信息归档,然而ApiManager无法做到在线调试和验证。在经过一段时间调研后最终选择了Yapi作为ApiManager的后继者(说白了又不想花钱,又要功能齐全的话开源的Yapi不失为一个比较理想的解决方案)。
那为什么不直接在项目中使用SwaggerUI呢?随项目启动且不用额外编写接口信息,通过注解就直接解决大部分文字注释的问题,并且可以直接对项目进行调试非常方便。
首先并不是SwaggerUI不好用,这边主要考虑的点有几个:
- Swagger是非必要依赖,整合它不会在性能上给到项目提升,反而会在加载的时候给额外分配资源(AutoConfigure会加载),在生产环境上是没有必要的;
- 接口信息不能随意暴露出来,譬如现在在测试环境有个项目整合了Swagger,而这个项目由于需要演示进行了外部映射,这个时候外网就能够扫描到Swagger的页面和接口地址,从而增加了运维面临的风险,同理生产环境下也是如此。当然了,在生产的环境下把Swagger做成配置型开启和关闭就可以了。是的,这样做是可以的,但是这样集成它又何苦呢;
- 接口信息属于项目组织过程资产的一部分,你项目停了就不能看了,也不能归档了?
- 一般代码中是不建议写中文的,这个看过编码规范的都知道;
...除了这些还有很多很多,就不一一举证了。
但是在搭建Yapi的过程中也不是一帆风顺的(按照网上提供的搭建文章来一步一步做还是没有办法完整整合插件,最后只能靠猜给搞定了),下面就讲讲这个Yapi是如何搭建的。
首先为了方便我这边下载MongoDB的Docker镜像并部署:
docker pull mongo:latest
创建挂载目录并启动mongodb
mkdir -p /data/docker/mongodb
docker run -p 27017:27017 -name mongodb -v /data/docker/mongodb:/data/db -d mongo:latest
这样就可以了,先不用初始化mongodb因为后面cli安装时会初始化的。接着就安装nodejs和npm,这个比较简单就不详说了。在安装好nodejs之后就可以通过命令安装yapi
npm install -g yapi-cli --registry https://registry.npm.taobao.org
到此之外的安装都比较顺利,但是要注意安装后的yapi-cli执行文件是否有创建软连接到/usr/bin目录下,如果没有的话自己通过ln -s创建两个软连接到/usr/bin目录底下,一个命名为yapi,另一个命名为yapi-cli。接下来就可以通过yapi server启动初始化界面。接着就可以通过访问
http://xxx.xxx.xxx.xxx:9090就能够访问到部署页面,如下图:
到了这个环节就可以按照界面提示进行配置。在完成平台部署后先找到安装目录,并通过以下命令启动Yapi:
nohup node vendors/server/app.js &
之后就能够通过
http://xxx.xxx.xxx.xxx:3000访问到Yapi页面了。如下图:
登录账号是“管理员邮箱”,密码初始化为ymfe.org.自此Yapi算是搭建ok了,但是真正困难的来了。
由于管理系统一般都需要登录后访问,为的是拿到一个token信息。而接口调试时为了尽可能贴近真实场景也需要先获取token后再触发接口请求,因此每一次都需要重复“先登录,拷贝token,粘贴到接口header,再触发接口”是非常麻烦。因此需要在Yapi中安装一个插件使其在每一次请求前都先自动获取token,那就不用人手去“复制、粘贴”了。
还好为了解决这个问题yapi提供了一个
yapi-plugin-interface-oauth2-token的插件,如下图:
本想按照npm官网提示去做,结果还出现的各种报错。根据上图中版本描述所说,最新的插件版本在2020年10月,也就是说近1年多2年没有更新了。在使用
yapi plugin --name yapi-plugin-interface-oauth2-token
命令安装时先是报node-sass组件“访问权限不足”的问题,接着在命令前面加上sudo后又引发了新的问题......
通过npm rebuild node-sass后还是出现错误。在经过sudo npm audit fix修复后接着就尝试修改
yapi-plugin-interface-oauth2-token的版本为1.2.3(因为npm官网说如果用yapi plugin升级不行就将
yapi-plugin-interface-oauth2-token降级为1.2.3之后删除node_modules文件夹重新npm install)结果还是不行。
多次尝试无果后我就想会不会是我yapi的版本太高而插件的版本太低导致的,结果将yapi版本换为1.9.2(2022年5月版本),在安装完yapi之后再尝试进行插件的整合,结果还是报各种异常。
最终还是用回yapi和插件的最新版本,虽然结果跟第一次一样,如下图:
但是根据这个编译结果还是看出了点端倪,于是我对源码进行了修改,先是componentWillMount替换成UNSAFE_componentWillMount,再将componentWillReceiveProps替换成
UNSAFE_componentWillReceiveProps,全部替换后重新进行插件安装基本上所有的编译问题都已经解决了,就还剩下
Module parse failed: /data/yapi/vendors/node_modules/swagger-client/lib/resolver.js Unexpected token (119:38)
You may need an appropriate loader to handle this file type.
SyntaxError: Unexpected token (119:38)
这个问题。经过排查发现这个是因为swagger-client未能固定好版本引起的,于是修改了package.json中有关swagger-client的版本信息固定其为3.5.1版本后再尝试安装插件,结果就编译成功了。如下图:
编译成功后进入到yapi目录重新通过node vendors/server/app.js启动程序后就会发现在设置中多了个tab,如下图:
至此插件安装和yapi安装都完成了。
相关推荐
- 怎么恢复7z文件 7z文件删除了怎么恢复
-
7z是一种压缩格式的文件,它运用LZMA压缩算法,该压缩算法的输出稍后被算数编码进行处理以便后续进一步压缩,压缩比十分高。我们可以将文件压缩成这种格式,便于传输,保存,占空间少。了解更多7z文件知识...
- 郎酒让消费者喝得明明白白 算术题里有答案
-
日前,『郎酒酱香产品企业内控准则』颁布,郎酒首次公开酱香产品生产全过程,公布酱香产品产能、储能及投放计划。随后,郎酒官微向消费者发出「品控算术题」有奖问答。郎酒亮出家底,消费者踊跃留言。8天后,谜底揭...
- 学龄前,比识字、算术更重要的是这三件事
-
“为了给孩子选择一家合适的幼儿园,我曾穿梭于纽约各家幼儿园的开放日,这些幼儿员既包括主流的公立幼儿园,还包括那些遥不可及的私人幼儿园。我的目的就是想了解他们的教育理念是什么,到底厉害在哪里,看看对于我...
- 参加CSP-J信奥赛需要掌握数学知识
-
在C++语法的学习中需要储备的数学知识如下①数据类型:需要知道整数、正整数、负整数、小数、判断对错②算术运算符:加法、减法、乘法、除法、取模运算③关系表达式:大于、大于等于、小于、小...
- 1g米饭能做多少深蹲?今天我们来算一算
-
减重我们都知道3分在练,7分在吃,吃这件事情上,真的是每一口都算数。今天我们来算一笔账,1粒米饭可以做多少事情?本着认真负责的态度,今天在食物秤上称了1g米饭,是16粒。根据能量换算:100g米饭是4...
- web 自动化测试,一定得掌握的 8 个核心知识点
-
使用cypress进行端对端测试,和其他的一些框架有一个显著不同的地方,它使用JavaScript作为编程语言。传统主流的selenium框架是支持多语言的,大多数QA会的pytho...
- 大话C语言:赋值运算符(c语言中赋值运算符是什么)
-
赋值运算符是最基本的运算符之一,用于将右侧的值或表达式的计算结果赋给左侧的变量。它是一个二元运算符,意味着它需要两个操作数:一个是目标变量(左侧),另一个是要赋给该变量的值或表达式(右侧)。赋值运算符...
- Vue进阶(幺幺伍):js 将字符串转换为boolean
-
Boolean();参数为0、null和无参数返回false,有参数返回true。Boolean("");//输出为:falseBoolean(null);//输出为...
- mongodb查询的语法(大于,小于,大于或等于,小于或等于等等)
-
1).大于,小于,大于或等于,小于或等于$gt:大于$lt:小于$gte:大于或等于$lte:小于或等于例子:db.collection.find({"field":{$gt:valu...
- Python学不会来打我(21)python表达式知识点汇总
-
在Python中,表达式是由变量、运算符、函数调用等组合而成的语句,用于产生值或执行特定操作。以下是对Python中常见表达式的详细讲解:1.1算术表达式涉及数学运算的表达式。例如:a=5b...
- C|数据存储地址与字节偏移、数据索引
-
话说C是面向内存的编程语言。数据要能存得进去,取得出来,且要考虑效率。不管是顺序存储还是链式存储,其寻址方式总是很重要。顺序存储是连续存储。同质结构的数组通过其索引表示位置偏移,异质结构的结构体通过其...
- 下班后累懵?4 个 JS 手写题帮你搞定前端面试高频考点
-
打工人下班后最痛苦的事,莫过于拖着疲惫的身子还要啃前端面试题吧?看着那些密密麻麻的JS代码,脑子都快转不动了!别担心,今天咱就用轻松的方式,带你吃透4道高频手写题,让你在面试时自信满满,再也不...
- 嵌入式数据库sqlite3【进阶篇】-子句和函数的使用,小白一文入门
-
sqlite在《嵌入式数据库sqlite3命令操作基础篇-增删改查,小白一文入门》一文中讲解了如何实现sqlite3的基本操作增删改查,本文介绍一些其他复杂一点的操作。比如where、orderby...
- 前缀表达式与后缀表达式(前缀表达式后缀表达式中缀表达式计算)
-
昨天晚上和儿子一起学习了前缀表达式和后缀表达式。这应该是字符串算式如何被计算机识别并计算的2种方法。本来是想先给他讲一个逆波兰式(后缀表达式),以后再讲前缀表达式。没想到他还挺聪明,很快就把2个都掌握...
- Python快速入门教程1:基本语法、数据类型、运算符、数字字符串
-
Python3的基础教程,涵盖了基本语法、数据类型、类型转换、解释器、注释、运算符、数字和字符串等内容,并附有使用实例场景。Python3的基础教程,涵盖了基本语法、数据类型、类型转换、解释器、注释、...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 简介 (30)
- HTML 响应式设计 (31)
- HTML URL 编码 (32)
- HTML Web 服务器 (31)
- HTML 表单属性 (32)
- HTML 音频 (31)
- HTML5 支持 (33)
- HTML API (36)
- HTML 总结 (32)
- HTML 全局属性 (32)
- HTML 事件 (31)
- HTML 画布 (32)
- HTTP 方法 (30)
- 键盘快捷键 (30)
- CSS 语法 (35)
- CSS 选择器 (30)
- CSS 轮廓宽度 (31)
- CSS 谷歌字体 (33)
- CSS 链接 (31)
- CSS 定位 (31)
- CSS 图片库 (32)
- CSS 图像精灵 (31)
- SVG 文本 (32)
- 时钟启动 (33)
- HTML 游戏 (34)