女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

深度“盤”一下Eolink這款免費API協作平臺

jf_ro2CN3Fa ? 來源:芋道源碼 ? 作者:芋道源碼 ? 2022-12-15 14:59 ? 次閱讀

寫代碼,哪個程序員都不害怕。

寫文檔,哪個程序員都害怕!

為什么?

還不是因為 API 工具不好使,不便捷,同步麻煩,測試看不懂……

最近調研了身邊一些開發團隊,發現他們列舉的工具中,都出現過同一款工具——Eolink。

今天這次我們深度“盤”一下 Eolink 這款免費 API 協作平臺,圍繞【智能生成+盤活 API 資產】這一功能上,到底投入了多大的開發成本,給我們帶來了多少驚喜!

快速體驗:https://www.eolink.com/?utm_source=w5104

本文重點圍繞以下產研需求展開(文末有福利)。

  1. 當 API 代碼更新之后,API 文檔自動刷新;

  2. API 協作工具通過腳本進行自動刷新/同步;

  3. 基于 API 文檔智能生成請求代碼和業務代碼;

當然在正式開始對接 Eolink 前,咱需要先使用 Python Flask 框架在本地構建一個微型項目,用于寫接口代碼。

閱讀完這篇,你不但可以編寫公司標準的 Python API 文檔,還順便掌握了 Swagger 與 Eolink 的對接,一舉多得,一文多獲。

一、Eolink 準備工作,Python 快速搭建 Swagger

我選用的 Web API 框架 Flask,所以搭建 Swagger 需要用到 Flasgger 模塊,如果你用 FastAPI,可以不用多走這一步,直接使用 FastAPI 原生 API 文檔即可。

使用 Flasgger 得到一個 Swagger UI 具體步驟,不做重點描述,咱們的目標是打通 SwaggerEolink,讓 API 研發資產可以盤活,Swagger 簡易部署流程請參考下述步驟。

首先安裝 flasgger 模塊。

pipinstallflasgger

然后新建 main.py 文件,同時輸入如下代碼(本地 Python 版本為 3.8),代碼有點長,可以跳過閱讀,直接復制代碼到本地相應文件中

fromflaskimportFlask
fromflasggerimportSwagger

app=Flask(__name__)
swagger=Swagger(app)


@app.route('/eolink_user_add/',methods=['POST'])
defeolink_user(user):
"""
添加用戶
---
tags:
-用戶相關接口
description:
用戶注冊接口,json格式
parameters:
-name:body
in:body
required:true
schema:
id:添加用戶
required:
-username
-password
properties:
username:
type:string
description:用戶名
password:
type:string
description:密碼
phone:
type:string
description:手機號
wx:
type:string
description:微信

responses:
201:
description:注冊成功


example:{'code':1,'message':注冊成功}
406:
description:注冊失敗
"""
pass


@app.route('/eolink_opts/')
defeolink_opts(t):
"""
Eolink功能描述
---
tags:
-第一個測試接口
description:
傳入大類,返回清單
parameters:
-m_type:number
in:number
type:string
enum:['eolink','eolink1','eolink2','eolink3']
required:false
default:eolink
responses:
200:
description:功能清單
examples:{'eolink':['一站式API生產力工具','超強的API管理','超方便的API測試']}
"""
all_eolink_opts={
'eolink1':['API文檔與研發管理','API監控和異常告警','API快速測試與自動化測試','API微服務網關'],
'eolink2':['支持所有主流協議','代碼自動生成API文檔','API文檔自動生成代碼','API版本管理','API變更通知'],
'eolink3':['支持在線、本地、客戶端進行測試','一鍵進行回歸/冒煙測試','快速創建測試用例','自動生成測試數據','豐富詳細的測試報告']
}
ift=='eolink':
result=all_eolink_opts
else:
result={'eolink':all_eolink_opts.get(t)}

returnresult


@app.route('/',methods=['GET'])
defhello():
return"helloworld!"


if__name__=='__main__':
app.run()

使用 python main.py 運行 Flask 項目,然后訪問 http://127.0.0.1:5000/apidocs/在瀏覽器得到如下視圖,如果此時你獲得界面與我一直,那么恭喜你,準備工作已經完成,后續我們需要對上述代碼進行修改,目的是在 Eolink 每次 自動生成 API 文檔 之后,對比差異。

作為一名合格的軟件研發工程師,在公司團隊協作開發的時候,一定要遵守團隊 API 文檔規范,邊寫代碼,邊寫注釋,邊寫文檔。

34d4cd3a-7c3d-11ed-8abf-dac502259ad0.png

在上述界面中,找到 appispec_1.json 超鏈接位置,點擊該鏈接,頁面跳轉到 Swagger 生成的 JSON 文件地址,如下所示。

http://127.0.0.1:5000/apispec_1.json

在瀏覽器中直接打開該 URL 地址,得到如下 JSON 格式的數據,下圖為部分內容展示。

34ec44ec-7c3d-11ed-8abf-dac502259ad0.png

二、Eolink 通過 Swagger 文件,自動生成 API 文檔

在前文拿到 JSON 文件地址后,就可以在 Eolink API 研發管理平臺讀取該網絡文件,并自動生成API文檔頁面了,具體操作如下。

進入 API 管理控制臺具體項目中左側菜單欄找到【其它】,然后選擇【API文檔生成】。

可按下述動圖進行操作。

34fa79cc-7c3d-11ed-8abf-dac502259ad0.gif

進入到 【自動生成API文檔】功能頁之后,選擇【添加來源】按鈕。

35117550-7c3d-11ed-8abf-dac502259ad0.png

在彈窗中選擇通過 Swagger URL 生成 API 文檔,點擊下一步:

352520fa-7c3d-11ed-8abf-dac502259ad0.png

【添加來源】彈窗輸入 Swagger 生成的 JSON 文件地址,就是剛剛得到的 JSON 文件地址,這里一定要注意,該地址能通過外網訪問(因為 Eolink 服務器不能調用我們本地的數據),并且為 JSON 格式(剛剛已經核對過目標數據),然后參考下圖進行填寫。

上傳前文獲取的 JSON 文件到臨時服務器,修改 Swagger.json 文件地址,點擊確定,完成配置。

互聯網公司項目,文檔一般是支持外網訪問的,這個問題只會在我們學習階段碰到。

3537298a-7c3d-11ed-8abf-dac502259ad0.png

注意:上圖右側【完善配置】所有數據保持默認即可。

點擊確定,完成來源配置,配置頁面自動關閉,出現如下列表。

355e10b8-7c3d-11ed-8abf-dac502259ad0.png

點擊同步按鈕,將 Swagger 文件內容同步到 Eolink 中。

356ed70e-7c3d-11ed-8abf-dac502259ad0.png

再次切換到 API 列表頁面,可以看到 API 同步之后的效果。

358e01ce-7c3d-11ed-8abf-dac502259ad0.png

此時打開 任意API 文檔,可以查看到 API 描述,請求地址,請求參數,返回參數等其它信息,到這里 Eolink 已經成功進行同步。

如果我們 JSON 文件發生了任意修改,例如【添加用戶接口】新增加一個 “年齡" 參數,此時只需要點擊上文提及的同步按鈕,即可更新 Eolink 平臺 API 詳細數據。

這里咱們需要做一個小小的總結,在公司團隊協作的場景下,經常出現文檔和代碼不同步情況,所以我們引入了 Swagger 模塊,讓小組中的程序員,在編寫代碼的同時,只需要更新自己的代碼和注釋,即可自動生成 API 文檔。

但 Swagger 只是一個用于生成、描述和調用 RESTful 接口的 Web 服務,它遠遠無法滿足團隊中對于API 的所有訴求,而 Eolink 在軟件研發整個生命周期中,做了全方位的補充,從而 盤活 API 研發資產。

除了手動點擊【同步】操作外,我們還可以通過 Open API 實現自動同步。

三、Eolink 通過 Open API 觸發同步操作

本篇博客中使用的是 Open API V2 版本,在正式編寫代碼前,需要先在工作空間管理后臺獲取調用密鑰。

密鑰配置

點擊在管理后臺右上角頭像位置的【賬號設置】,進入工作空間設置菜單。

切換的頁面中,選擇 【Open API】,進入密鑰配置。

35a1231c-7c3d-11ed-8abf-dac502259ad0.png

為了數據安全,請不要將密鑰泄露。點擊上圖箭頭指向位置,查看密鑰明細,直接點擊即可復制。

解析來我們查看一下 通過 Open API 觸發同步操作的請求說明。

  • 請求協議:HTTPS

  • 請求方式:GET

  • 請求地址:https://api.eolink.com/v2/api_studio/management/api/auto_scan

  • 請求參數:

    • eo_secret_key:open api 的訪問鑒權密鑰,前文剛剛復制的字符串。
    • project_id:當前項目的ID,在【自動生成API文檔】頁面已經自動填充。
    • space_id:工作空間ID,同樣為 Eolink 自動生成內容。
  • 請求響應

    • 數據請求成功,返回 JSON 格式數據,{"status":"success"}

有了這些標準之后,我們可以快速通過 Python 編寫一個自動觸發同步操作的腳本,代碼如下。

importrequests

url="https://api.eolink.com/v2/api_studio/【其余內容請在API文檔生成頁面復制】"

res=requests.get(url)

print(res.text)

在運行代碼前,先對前文的 Python Flask 接口代碼進行一下修改,增加【用戶來源】字段。然后使用上面的 3 行代碼,即可實現自動化同步。上述代碼運行結果如下所示。

{"type":"api","status":"success"}

閱讀到這里,我們已經實現了【通過 Open API 觸發同步操作】,你可以將代碼部署到云服務器,并設置成自動任務,這樣 Eolink 就可以實時的抓取服務端 API 文檔,解放你的雙手了。

四、Eolink 基于 IDEA 插件上傳 API

Eolink 除了手動同步和以Open API 形式同步文檔以外,還可以通過 IDEA 插件實現快速在研發工具上操作并上傳API接口文檔,而且比Swagger的方式還快,具體步驟如下所示。

打開 IDEA 插件,再插件市場搜索 Eolink ApiKit。

35c1c31a-7c3d-11ed-8abf-dac502259ad0.png

點擊上圖的 Install 即可安裝。

接下來就需要對該插件進行配置,參照下圖找到 Eolink Settings。

35d97cbc-7c3d-11ed-8abf-dac502259ad0.png

看一下 Eolink Settings 中的相關參數配置。

  1. Server:這里使用域名+/api 格式,例如這里是 https://space-e87yzg.w.eolink.com/api;

  2. SpaceKey:空間Key,復制上述域名中的Key即可,space-e87yzg;

  3. ProjectHashKey:前文 Open API 中用到的 密鑰

  4. Token:你的賬號;

  5. StringType:選擇第一項即可。

然后在你的項目源碼空白處,點擊樹表右鍵,選擇 Generate Class Doc,一鍵生成全部 API 注釋文檔。

35fa04d2-7c3d-11ed-8abf-dac502259ad0.png

生成完畢,再次選擇 Upload All Api 即可上傳所有 API 注釋到目標服務器,真正的一鍵生成文檔,一鍵上傳文檔,如果你恰好使用的是 IDEA ,一定要嘗試一下該方式,在 Eolink 的幫助下,寫文檔會變成一件非常輕松的事。

五、基于 Eolink API 文檔智能生成請求代碼和業務代碼

前文我們做的所有工作,都是為了讓現有 API 文檔快速生成并同步到 Eolink 中,只有這樣,我們才能體驗 Eolink 這個一站式 API 生產力工具,盤活 API 研發資產時的強大。

下面將借助剛剛建立的接口,為大家展示 Eolink API 智能生成請求代碼和業務代碼這一重點功能,過程中還將為大家介紹 Eolink 的一些小細節亮點。

API 文檔同步到 Eolink,一切才剛剛開始!

選擇進入前文同步的任意接口中,可以得到該接口的詳細描述,更多內容可在你的 Eolink 后臺查看,這里僅展示局部。

361882cc-7c3d-11ed-8abf-dac502259ad0.png

如果你善于發現,一定會發現一個非常不起眼的按鈕 ---【生成預覽數據】,點擊它。這個操作非常適合測試工程師進行數據模擬,尤其是當 API 接口包含大量參數待填寫時,可以大幅度節約手寫參數的消耗時間,而且測試的時候,可以避免使用 abc,aaa,1111,123,這些 “左手亂敲” 的輸入數據。

3639dc9c-7c3d-11ed-8abf-dac502259ad0.gif

然后我們再看一個強大的功能,生成請求代碼和業務代碼,你可以借助 Eolink 生成指定 API 的語言調用代碼,操作非常便捷,只需要點擊API文檔詳情頁右上角 “代碼示例” 圖標即可。

368b5b62-7c3d-11ed-8abf-dac502259ad0.png

在彈出的抽屜頁中,可以選擇你需要的代碼示例,這里依據實戰應用場景進行選擇,例如我需要的是 NodeJS 代碼,選擇對應語言類型之后,可以得到下圖所示內容,下載腳本即可用于請求代碼和業務代碼。

369d2202-7c3d-11ed-8abf-dac502259ad0.png

最后,我們在補充一個 Eolink 的亮點功能,Eolink 可以直接發起 API 測試,并且可以在接口前后增加 前置腳本后置腳本,二者的原理是在 API 執行前/后 執行 Javascript 腳本,從而改變請求參數或者進行簽名加密等操作。

這部分內置變量和內置函數,學習和使用時可以參考 Eolink 手冊,點擊閱讀。

使用方式非常簡單,給大家羅列幾個 HTTP 請求相關的函數,如下所示。

//輸出信息
eo.info("輸出自定義信息");

//設置http協議url,比如/user/login/admin?user_name={{name}}
eo.http.url.set("http://www.baidu.com");

//MD5加密
eo.crypt.md5(data)

上述內置函數,搭配上 Eolink 的 API 自動化測試,可以最大限度的擴展自動化測試需求,真正實現了一鍵發起測試,一鍵進行 API 回歸測試。

六、總結

本篇博客,我們從 Eolink 與 Python Flask Swagger 文件打通開始,為大家介紹了兩種 Eolink 同步API 文檔的方法,實戰中還是建議大家在服務器端部署 Open API 同步腳本,自動化實現 Swagger 和 Eolink 同步。

在同步的時候,我們可以進行更加詳細的配置,擴展如下。

  • 數據同步方式:增量更新、全量更新、僅添加新API時更新;

  • 同步接口唯一標識:可選 接口標識,接口地址和請求方式,接口名稱;

  • 新生成 API 文檔狀態設置:已發布,設計,待定,開發,測試等;

  • 將發生變更的 API 文檔狀態設置為:已發布,設計,待定等;

  • 將新生成 API 文檔歸到指定分組:可選API 分組目錄。

Eolink 增加了非常詳細的同步配置,多方面完善API文檔更新細節。

除了API同步外,本文還給大家介紹了 Eolink 的幾個亮點功能,例如自動生成預覽數據,快速生成請求代碼和業務代碼,前置后置腳本添加。

審核編輯 :李倩


聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • API
    API
    +關注

    關注

    2

    文章

    1563

    瀏覽量

    63559
  • 工具
    +關注

    關注

    4

    文章

    314

    瀏覽量

    28176

原文標題:老油條用什么工具寫文檔?

文章出處:【微信號:芋道源碼,微信公眾號:芋道源碼】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    3Dfindit 的協作功能

    專有部件庫。 []()促進團隊協作 單點登錄(SSO)使設計人員只需點擊一下即可訪問 COLLABORATION 3Dfindit 。公司可隨時快速、輕松地添加或刪除團隊成員。關鍵績效指標(KPI
    發表于 06-09 14:35

    設計優先方法論實踐:SmartBear API Hub +ReadyAPI組合使用,構建高效的API開發流

    設計優先是種在編寫代碼和執行測試之前,優先設計API接口的開發方式,能夠幫助提升團隊協作效率、加快開發進度、減少Bug和返工,并改善用戶體驗。如何實現?——將該與SmartBear API
    的頭像 發表于 06-05 16:03 ?76次閱讀
    設計優先方法論實踐:SmartBear <b class='flag-5'>API</b> Hub +ReadyAPI組合使用,構建高效的<b class='flag-5'>API</b>開發流

    ReviewHub:實現Booster與設計工具端無縫鏈接的評審協作平臺

    在電子產品設計與質量管理中,跨部門的高效評審協作至關重要。傳統線下評審方式因時間、地點和信息孤島等限制,效率低下且易出錯。ReviewHub作為款貫穿Booster與設計工具端的線上評審平臺,憑借
    的頭像 發表于 06-04 11:46 ?125次閱讀
    ReviewHub:實現Booster與設計工具端無縫鏈接的評審<b class='flag-5'>協作</b><b class='flag-5'>平臺</b>

    集成API設計+測試+文檔管理,全新站式解決方案SmartBear API Hub功能介紹

    SmartBear全新推出API Hub,助力高效應對API開發挑戰! API Hub專為API開發者、架構師、產品經理和QA團隊打造,將設計、測試、治理和文檔集成到
    的頭像 發表于 04-08 17:52 ?249次閱讀
    集成<b class='flag-5'>API</b>設計+測試+文檔管理,全新<b class='flag-5'>一</b>站式解決方案SmartBear <b class='flag-5'>API</b> Hub功能介紹

    Claude 3.7:編碼助手首選,claude api key如何申請獲取與深度解析*

    核心看點 混合推理引擎 :Claude 3.7 融合快速代碼生成與深度問題解決能力,實現“快思考”與“深思考”的無縫切換。 便捷API訪問 :三步快速獲取Claude 3.7 API密鑰,安全、簡單
    的頭像 發表于 03-24 09:43 ?781次閱讀
    Claude 3.7:編碼助手首選,claude <b class='flag-5'>api</b> key如何申請獲取與<b class='flag-5'>深度</b>解析*

    請問STM32cubeProgrammer是否有提供API用于設計定制化的升級軟件?

    的應用。其實也可以理解為這款應用是對STM32cubeProgrammer的個模仿,只不過GUI界面是定制為我們公司的。 所以我想問一下STM32cubeProgrammer是否有提供
    發表于 03-07 07:27

    openai api key獲取的三種方案(有種可以白嫖到 api key)

    OpenAI API Key 全攻略:官方獲取、費用詳解與“白嫖”實戰 引言: 想要體驗 OpenAI 強大的 GPT 模型,卻苦于沒有 API Key?別擔心,本文將為你提供份詳盡
    的頭像 發表于 02-24 22:16 ?8698次閱讀
    openai <b class='flag-5'>api</b> key獲取的三種方案(有<b class='flag-5'>一</b>種可以白嫖到 <b class='flag-5'>api</b> key)

    國家超算互聯網免費開放3個月DeepSeek API接口

    2月11日晚,國家超算互聯網平臺正式推出“AI生態伙伴加速計劃”,旨在推動AI技術的快速發展與應用。作為該計劃的重要組成部分,平臺決定免費開放DeepSeek API接口3個月,為AI
    的頭像 發表于 02-13 15:21 ?721次閱讀

    “碰一下”支付背后的4G技術

    不知道你是否有留意,近期,在線下支付場景中,多了個支付寶“碰一下”支付的設備,只需要“解鎖手機—碰一下—確認”即可完成支付,對比打開付款碼支付,步驟確實更加簡潔。
    的頭像 發表于 01-03 16:27 ?1299次閱讀

    LG全面開放ThinQ智能家居平臺API

    近日,LG宣布將全面開放其ThinQ智能家居平臺的應用程序編程接口(API)。此舉旨在構建更加廣泛的智能家居生態系統,推動智能家居技術的創新與發展。 據悉,LG將API分為了兩種類型,分別是面向
    的頭像 發表于 12-18 11:11 ?735次閱讀

    如何在低成本ARM平臺部署LVGL免費圖形庫,基于全志T113-i

    :完全免費,遵循開源協議,促進社區共享與協作。 控件資源豐富:提供豐富的控件,動畫效果流暢,增強GUI的交互性和視覺吸引力。 跨平臺可移植:支持多種操作系統和硬件平臺,易于在不同環境中
    發表于 10-29 09:55

    使用API Post測試阿里云物聯網平臺動態注冊

    使用API Post測試阿里云物聯網平臺動態注冊
    的頭像 發表于 10-05 19:08 ?709次閱讀
    使用<b class='flag-5'>API</b> Post測試阿里云物聯網<b class='flag-5'>平臺</b>動態注冊

    探索機器人快換技術的未來之路:智能化與協作的革新

    機器人快換技術正經歷變革,AI、機器學習、傳感器、機器視覺及協作技術將推動其智能化、高效化、靈活化發展,提升生產效率,成為產業升級的重要力量。
    的頭像 發表于 09-26 11:26 ?489次閱讀

    全球視野API資源,看冪簡集成如何整合國內外API

    在全球數字化浪潮的推動API(應用程序編程接口)已成為連接不同系統和數據的橋梁,是企業數字化轉型的關鍵。全球各地的企業都在進行數字化轉型,它們不約而同地尋求通過API快速集成新技術,以提高效率
    的頭像 發表于 07-30 14:23 ?503次閱讀
    全球視野<b class='flag-5'>下</b>的<b class='flag-5'>API</b>資源,看冪簡集成如何整合國內外<b class='flag-5'>API</b>

    歡創播報 支付寶“碰一下”正式發布

    1 支付寶“碰一下”正式發布 近日,在支付寶開放日上,支付寶宣布升級條碼支付體驗,推出“支付寶碰一下”,用戶無需展示付款碼,解鎖手機碰一下商家收款設備,最快步完成支付。據介紹,“碰
    的頭像 發表于 07-11 11:32 ?1400次閱讀
    歡創播報  支付寶“碰<b class='flag-5'>一下</b>”正式發布