让文档参与到你的开发中,帮助你提高效率 - XJZProxy

2019-05-28 18:20:37 +08:00
 xjz19901211

官网 https://xjzproxy.xjz.pw/zh-cn/

主要功能:


通常我们合作开发时都是:

商量接口文档 => 使用者自己生成假数据开撸 =>   最对接真实接口,发现不对再改
          \\=> 开发接口                                 //

甚至是

商量接口文档 => 开发接口 => 等接口好 => 发现不对再改接口或文档

最后基本都是接口使用者拿到文档时没有真实接口可以用。真实接口好了后,改着改着真实接口和文档完全不一样了。

此工具就是为了提高这一过程的效率。一个最简单的示例

先在创建项目并写个文档(YAML 格式)

project:
  host: mydomain.com

apis:
  - title: Get a user
    method: GET
    path: /api/v1/users/\d+
    response:
      success:
        http_code: 200
        data:
          id: 1
          name: .t/name

然后就可以通过 XJZProxy 代理来访问了

$ curl http://mydomain.com/api/v1/users/123 --proxy localhost:9898
{"id": 1, "name": "random name"}

当然,在工具中查看渲染好的漂亮文档也是不能少的。更多文档格式请参考 这里


有兴趣的朋友可以在 这里 下载(目前只支持 MacUbuntu,其它 linux 系统的包看情况再折腾了),然后发邮件到 base64 eGllamlhbmd6aGlAZ21haWwuY29t。我会给前 100 名发放永久证书哟。记得带上标题 "XJZProxy 证书申请",不然我可能注意不到。当然,没有证书的话,也可以享受完整的代理功能及受限的文档代理功能。

2027 次点击
所在节点    程序员
14 条回复
xjz19901211
2019-05-28 20:54:16 +08:00
这么多点击居然无一回复。。。

求试用,求反馈!
marsgt
2019-05-28 21:04:50 +08:00
Windows 平台开发者,不太好回复。。

你这个我觉得有点类似 VSCode 上的 REST Client 插件( https://github.com/Huachao/vscode-restclient ),只不过他用的是 REST 格式,你用的是 YAML。
但是它作为插件应该能支持全平台。。😂
xjz19901211
2019-05-28 23:35:27 +08:00
@marsgt 感谢回复,看了下 rest client,没看懂😭。可能是因为我没用过 vscode。等我明天再花时间了解一下。
对我这新手来说,编译个 windows 版本大概要花很多时间。以后看情况再考虑 windows 了😏
star7th
2019-05-29 14:59:27 +08:00
粗略看一下不想浪费太多时间。不回复可能是大多数人没这个需求,不是技术上的问题。
xjz19901211
2019-05-29 16:26:03 +08:00
@marsgt 发现可能是我描述的不清楚, 这个工具相当于一个代理 + 文档化的本地服务器。和 http client 基本没关系。。

定义好文档后,我们完全可以在没有接口服务器的情况下,发送真实的请求(只需要设置 http 代理),得到相应格式的数据。通过开关可以直接在文档数据和真实服务器数据之间切换。除了配置代理,代码中完全不需要任何变动
xjz19901211
2019-05-29 16:45:22 +08:00
@star7th 多谢反馈。所以我要忽悠点人来才能得到更多反馈,哈哈
marsgt
2019-05-29 16:48:50 +08:00
@xjz19901211
那应该是我理解的问题,感觉相当于前端调试用的 mock Server ?感觉是不是和 YApi 类似啊
xjz19901211
2019-05-30 09:46:27 +08:00
@marsgt 工具的定位是提高协作开发效率。目前已经完成的功能,大部分都是相当于一个本地的 mock 服务。

我们的目标是以 `api 文档` 为联结点来解决前后端协作问题。简单来说就是前后端使用这个工具来辅助开发,大家只要都满足了文档了定义(工具自动基于文档定义去检查),那么所有工作完成后,真实的对接也是没有问题的。

对前端来说,有了这份文档就可以直接开始调用接口、调试了。
对后端来说,通过这份文档,也可以验证真实的 api 接口是否与约定的一致。不过,后端方面的功能还在开发中。目前只能在配合前端调用来检查真实接口是否符合定义,而无法单独使用。
xjz19901211
2019-05-30 09:56:24 +08:00
@marsgt 非常感谢你的反馈。讨论中发现工具完全没有描述清楚。下一版做好了再更新下,哈哈
marsgt
2019-05-30 10:37:38 +08:00
@xjz19901211
嗯,如果开始能有句 slogan,开始就说明这个产品(目前)提供了私有化本地部署的 Mock Server 服务,并用文档(约定)的方式解决了前后端调试接口的痛点,我可能就不会绕个大圈了。。😂
xjz19901211
2019-06-05 17:51:16 +08:00
Hi @marsgt 这几天更新了下功能和界面体验。然后介绍也修改了。
发到创意区了 https://www.v2ex.com/t/571213
有兴趣来给点意见建议嘛?
xjz19901211
2019-06-16 11:31:06 +08:00
@marsgt 已经撸了个 Windows 版本出来,试用证书也内置到软件中了,要不要来试试?
由于不是 windows 原生的,性能相对 *nix 慢点,正在努力优化。
marsgt
2019-06-16 14:18:20 +08:00
@xjz19901211
好像链接有点问题,下载不了(不过也不排除是我网的问题🤦‍♂)。。
建议直接放百度云上吧~
xjz19901211
2019-08-02 20:14:37 +08:00
@marsgt 没注意这边,都去玩游戏去了。

没人用啊,一怒之下开源了 https://github.com/xiejiangzhi/xjzproxy 哈哈哈

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/568496

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX