什么是鏈接 API 請(qǐng)求,為什么需要它?

鏈接 API 請(qǐng)求(也稱為管道請(qǐng)求或順序 API 調(diào)用)是一種在軟件開發(fā)中管理 API 交互復(fù)雜性的技術(shù)。當(dāng)一個(gè)任務(wù)需要多個(gè) API 調(diào)用才能完成時(shí),這種技術(shù)尤為重要。它類似于批量請(qǐng)求處理,但不同之處在于,管道請(qǐng)求通過一個(gè)請(qǐng)求觸發(fā)一系列按定義順序執(zhí)行的 API 調(diào)用。序列中的每個(gè) API 請(qǐng)求可以修改請(qǐng)求和響應(yīng)數(shù)據(jù),且來自一個(gè) API 請(qǐng)求的響應(yīng)將作為下一個(gè) API 請(qǐng)求的輸入。當(dāng)客戶端需要按照特定順序執(zhí)行一系列依賴的 API 請(qǐng)求時(shí),管道請(qǐng)求尤為有用。

在管道的每個(gè)步驟中,可以對(duì)響應(yīng)數(shù)據(jù)進(jìn)行轉(zhuǎn)換或操作,然后再傳遞到下一步。這種方法在需要對(duì)數(shù)據(jù)進(jìn)行規(guī)范化、轉(zhuǎn)換或篩選敏感數(shù)據(jù)時(shí)非常有效。它還能幫助減少整體延遲,例如,在等待一個(gè) API 調(diào)用響應(yīng)時(shí)進(jìn)行另一個(gè) API 調(diào)用,從而縮短完成工作流程所需的總時(shí)間。

自定義 Pipeline-Apache APISIX 請(qǐng)求插件

API 網(wǎng)關(guān)是實(shí)現(xiàn)該功能的理想位置,因?yàn)樗軌驍r截所有客戶端請(qǐng)求并將其轉(zhuǎn)發(fā)至目標(biāo)。本文將使用 Apache APISIX,這是一款流行的開源 API 網(wǎng)關(guān)解決方案,內(nèi)置了眾多插件。不過,目前 APISIX 并不官方支持 pipeline-request 插件。為了實(shí)現(xiàn)相同功能,我們決定開發(fā)一個(gè)新的插件。GitHub 上有一個(gè)存儲(chǔ)庫(kù),包含用 Lua 編寫的源代碼以及 pipeline-request 插件的說明。

通過此插件,可以指定按順序調(diào)用的上游 API 列表,以處理單一客戶端請(qǐng)求。每個(gè)上游 API 都能修改請(qǐng)求和響應(yīng)數(shù)據(jù),來自一個(gè)上游 API 的響應(yīng)將作為輸入傳遞給管道中的下一個(gè)上游 API。管道可以在 Route 配置中定義,同時(shí)可以設(shè)置管道中 API URL 的執(zhí)行順序。

以下是插件的一個(gè)使用示例。假設(shè)有兩個(gè) API:一個(gè)用于發(fā)出 GET 請(qǐng)求以檢索信用卡信息,另一個(gè)用于接收 POST 請(qǐng)求正文中的響應(yīng)數(shù)據(jù),并在將響應(yīng)返回給客戶端之前篩選敏感數(shù)據(jù)(如信用卡號(hào)和到期日期)。因?yàn)樾庞每?API 端點(diǎn)返回的信息包含不應(yīng)對(duì)未經(jīng)授權(quán)的各方公開的敏感數(shù)據(jù)。下圖展示了數(shù)據(jù)流的整個(gè)過程:/credit_cards/filter

當(dāng)客戶端向 API 網(wǎng)關(guān)的信用卡 API 端點(diǎn)發(fā)出請(qǐng)求以檢索信用卡信息時(shí),API 網(wǎng)關(guān)會(huì)將請(qǐng)求轉(zhuǎn)發(fā)至信用卡后端服務(wù)以獲取數(shù)據(jù)。

若請(qǐng)求成功并返回?cái)?shù)據(jù),數(shù)據(jù)將傳遞到管道中的下一步,即安全服務(wù)。

從安全服務(wù)收到篩選后的響應(yīng)后,API 網(wǎng)關(guān)將組合響應(yīng)返回給客戶端。

pipeline-request 插件演示

在本演示中,將使用 GitHub 上的現(xiàn)成演示項(xiàng)目,其中包含本教程所需的所有 curl 命令示例。無需使用 Docker compose.yml 文件進(jìn)行額外配置,即可運(yùn)行 APISIX 并啟用自定義插件。

先決條件

第 1 步:安裝并運(yùn)行 APISIX 和 etcd

在 fork 或 clone 項(xiàng)目后,從項(xiàng)目根目錄運(yùn)行,即可輕松安裝 APISIX 和 etcd。請(qǐng)注意,配置文件中指定了一個(gè)卷。這將本地目錄 掛載到 Docker 容器中,作為只讀卷,與我們的文件及自定義插件實(shí)現(xiàn)一起使用。此設(shè)置允許在運(yùn)行時(shí)向 APISIX 添加自定義插件(適用于使用 Docker 運(yùn)行 APISIX 的情況)。

運(yùn)行以下命令來啟動(dòng) Docker 容器:

docker-compose up

在配置文件 docker-compose.yml 中,配置如下:

volumes:
- ./custom-plugins:/opt/apisix/plugins:ro

./custom-plugins 目錄掛載到容器中的 /opt/apisix/plugins 目錄。

第 2 步:使用 pipeline-request 插件創(chuàng)建第一個(gè)路由

APISIX 啟動(dòng)后,可以使用 cURL 命令向 APISIX Admin API 端點(diǎn)發(fā)送 HTTP PUT 請(qǐng)求,以創(chuàng)建第一個(gè)監(jiān)聽 URI 路徑的路由 /routes/my-credit-cards

curl -X PUT 'http://127.0.0.1:9180/apisix/admin/routes/1' \
--header 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' \
--header 'Content-Type: application/json' \
--data-raw '{
"uri":"/my-credit-cards",
"plugins":{
"pipeline-request":{
"nodes":[
{
"url":"https://random-data-api.com/api/v2/credit_cards"
},
{
"url":"http://127.0.0.1:9080/filter"
}
]
}
}
}'

配置中最關(guān)鍵的部分是 "plugins" 部分,它指定了 "pipeline-request" 插件用于該 API 路由。插件配置包括一個(gè) "nodes" 數(shù)組,定義了管道中 API 請(qǐng)求的執(zhí)行順序。在這里,可以定義一個(gè)或多個(gè) API。

在這個(gè)示例中,管道包含兩個(gè)節(jié)點(diǎn):

  1. 第一個(gè)節(jié)點(diǎn)向 https://random-data-api.com/api/v2/credit_cards API 發(fā)送請(qǐng)求以檢索信用卡數(shù)據(jù)。
  2. 第二個(gè)節(jié)點(diǎn)向 http://127.0.0.1:9080/filter 發(fā)送請(qǐng)求,以從信用卡信息中篩選出敏感數(shù)據(jù)。第二個(gè) API 是一個(gè)使用 serverless-pre-function APISIX 插件的 serverless 函數(shù),它作為后端服務(wù),修改來自第一個(gè) API 的響應(yīng)。

第 3 步:使用 Serverless 插件創(chuàng)建第二個(gè)路由

接下來,配置一個(gè) ID 為 2 的新路由,以處理管道中的請(qǐng)求,并啟用 APISIX 的 serverless-pre-function 插件。我們將在此插件中指定一個(gè) Lua 函數(shù),該函數(shù)從上一個(gè)響應(yīng)中檢索請(qǐng)求正文,替換 credit_card_number 字段,并保持響應(yīng)的其他部分不變。最后,函數(shù)將修改后的請(qǐng)求正文設(shè)置為當(dāng)前響應(yīng)正文,并將 HTTP 200 響應(yīng)發(fā)送回客戶端。可以根據(jù)需要修改此腳本,例如對(duì)解碼后的正文進(jìn)行進(jìn)一步處理或驗(yàn)證。

路由配置示例如下:

curl -X PUT 'http://127.0.0.1:9180/apisix/admin/routes/2' \
--header 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' \
--header 'Content-Type: application/json' \
--data-raw '
{
"uri": "/filter",
"plugins": {
"serverless-pre-function": {
"phase": "access",
"functions": [
"return function(conf, ctx)
local core = require(\"apisix.core\")
local cjson = require(\"cjson.safe\")
-- 獲取請(qǐng)求正文
local body = core.request.get_body()
-- 解碼 JSON 正文
local decoded_body = cjson.decode(body)
-- 隱藏信用卡號(hào)
decoded_body.credit_card_number = \"****-****-****-****\"
core.response.exit(200, decoded_body)
end"
]
}
}
}'

第 4 步:測(cè)試設(shè)置

現(xiàn)在可以測(cè)試整體配置。使用以下 cURL 命令向端點(diǎn)發(fā)送 HTTP GET 請(qǐng)求:

curl http://127.0.0.1:9080/my-credit-cards

在第二步中配置的路由使用了帶有兩個(gè)節(jié)點(diǎn)的插件,該請(qǐng)求將觸發(fā)管道從端點(diǎn)檢索信用卡信息,利用端點(diǎn)過濾掉敏感數(shù)據(jù),并將修改后的響應(yīng)返回給客戶端。查看輸出結(jié)果:

{
"uid": "a66239cd-960b-4e14-8d3c-a8940cedd907",
"credit_card_expiry_date": "2025-05-10",
"credit_card_type": "visa",
"credit_card_number": "****-****-****-****",
"id": 2248
}

如圖所示,請(qǐng)求正文中的信用卡號(hào)(實(shí)際上是第一個(gè) API 調(diào)用的響應(yīng))已被替換為星號(hào)。

總結(jié)

到目前為止,我們了解了為 Apache APISIX API 網(wǎng)關(guān)定制的流水線請(qǐng)求插件的功能。該插件允許將一系列 API 調(diào)用定義為按特定順序的流水線,并且可以與現(xiàn)有插件結(jié)合使用,為 API 端點(diǎn)啟用身份驗(yàn)證、安全性以及其他 API Gateway 功能。

原文鏈接:使用 API Gateway 鏈接 API 請(qǐng)求 – API7.ai

熱門推薦
一個(gè)賬號(hào)試用1000+ API
助力AI無縫鏈接物理世界 · 無需多次注冊(cè)
3000+提示詞助力AI大模型
和專業(yè)工程師共享工作效率翻倍的秘密
返回頂部
上一篇
探索 2024 年最佳 API 發(fā)現(xiàn)工具
下一篇
免費(fèi)API攔截工具入門指南:初學(xué)者必備教程與實(shí)用技巧
国内精品久久久久影院日本,日本中文字幕视频,99久久精品99999久久,又粗又大又黄又硬又爽毛片
亚洲另类在线制服丝袜| 亚洲福利电影网| 久久无码av三级| 日韩不卡手机在线v区| 欧美巨大另类极品videosbest| 一级中文字幕一区二区| 欧美无砖砖区免费| 五月天欧美精品| 日韩精品一区二区三区在线观看 | 婷婷久久综合九色综合绿巨人| 国产在线精品国自产拍免费| 亚洲精品一区在线观看| www.欧美精品一二区| 精品国产乱码久久久久久图片| 日韩高清一级片| 日韩精品中文字幕一区| caoporm超碰国产精品| 亚洲精品久久久蜜桃| 久久免费偷拍视频| 欧美日韩黄色影视| www.久久久久久久久| 五月天一区二区| 国产精品美女久久久久aⅴ| 欧美男男青年gay1069videost | 蜜桃av一区二区三区电影| 欧美一区二区日韩一区二区| 色噜噜狠狠成人中文综合| 中文字幕字幕中文在线中不卡视频| 成人av在线资源网站| 国产大陆a不卡| 青青草91视频| 五月天一区二区三区| 亚洲国产精品一区二区www| 亚洲人成亚洲人成在线观看图片| 国产亚洲精久久久久久| 久久精品综合网| 在线亚洲免费视频| 91精品国产色综合久久不卡蜜臀 | 国产亚洲女人久久久久毛片| 久久一区二区视频| 欧美国产综合一区二区| 久久青草欧美一区二区三区| 欧美激情在线看| 午夜视频一区在线观看| 日韩精品久久理论片| 精品中文字幕一区二区小辣椒| 麻豆精品精品国产自在97香蕉| 国产精品久久三| 日韩福利电影在线| 色呦呦国产精品| 欧美一级专区免费大片| 欧美激情一区二区三区在线| 一区二区三区国产精华| 国产精品自拍网站| 欧美日韩国产精选| 国产精品久久久久久久久果冻传媒 | 激情久久五月天| 91免费在线播放| 精品乱码亚洲一区二区不卡| 亚洲欧美日韩成人高清在线一区| 免费看黄色91| 色婷婷综合在线| 国产精品久久久久久久久免费丝袜 | 久久精品欧美日韩| 国产一区二区毛片| 欧美久久久久免费| 26uuu国产电影一区二区| 久久疯狂做爰流白浆xx| 久久这里只有精品首页| 麻豆国产精品视频| 日韩一区二区中文字幕| 一区二区三区久久| 91.xcao| 免费在线视频一区| 欧美一区二区三区人| 久久99日本精品| 久久精品亚洲国产奇米99| 国产成人av自拍| 亚洲特黄一级片| 91精品国产综合久久久久久久| 久久精品国产亚洲高清剧情介绍 | 久久草av在线| 亚洲欧美国产毛片在线| 欧美日韩一区二区三区在线| 日本va欧美va瓶| 国产精品色一区二区三区| 91国产福利在线| 国产精品久久久久一区| 欧美伦理视频网站| 成人av午夜电影| 极品瑜伽女神91| 成人欧美一区二区三区1314 | 精品一区中文字幕| 久久午夜国产精品| 91丨porny丨在线| 不卡一卡二卡三乱码免费网站| 免费观看91视频大全| 欧美mv日韩mv国产网站app| 欧美特级限制片免费在线观看| 国产精品亚洲а∨天堂免在线| 免费观看30秒视频久久| 亚洲成人黄色小说| 亚洲美女在线一区| 91精品国产欧美一区二区成人| 91精品福利在线| 色综合久久九月婷婷色综合| 99久久久久免费精品国产 | 国产成人免费在线观看| 国产乱淫av一区二区三区| 九一久久久久久| 精彩视频一区二区三区| 国产一区二区精品在线观看| 国产成人超碰人人澡人人澡| 成人av网址在线| 欧美在线免费观看视频| 欧美日韩在线免费视频| 不卡视频一二三| 欧美高清性hdvideosex| 久久综合狠狠综合| 最新热久久免费视频| 亚洲免费观看高清完整版在线观看 | 三级在线观看一区二区 | 成人av电影免费观看| 国产精品18久久久久久久久| 久久国产人妖系列| av在线播放不卡| 在线视频欧美精品| 精品国产乱子伦一区| 国产农村妇女精品| 国产精品久久三| 亚洲国产精品综合小说图片区| 国产伦精品一区二区三区免费迷| 国内精品伊人久久久久av一坑| 欧美色精品在线视频| 国产精品美女久久久久久久网站| 亚洲18女电影在线观看| www.av精品| 久久亚洲精品小早川怜子| 日韩电影一区二区三区四区| 97精品视频在线观看自产线路二| 久久久精品欧美丰满| 六月丁香婷婷色狠狠久久| 欧美猛男男办公室激情| 一个色在线综合| 欧美亚洲综合在线| 午夜私人影院久久久久| 欧美肥胖老妇做爰| 激情综合色丁香一区二区| 日韩欧美色综合| 丝袜美腿亚洲色图| 欧美一级片在线看| 国产在线精品一区二区| 欧美日韩电影在线| 蜜桃视频第一区免费观看| 日韩欧美中文一区| 国产a精品视频| 亚洲国产美国国产综合一区二区| 欧美日韩一区成人| 亚洲精品国产无套在线观| 狠狠色综合日日| 亚洲精品一线二线三线| 欧美日韩一区二区在线视频| 久久国产福利国产秒拍| 一区免费观看视频| 欧美日韩精品免费观看视频| 蜜桃久久久久久久| 亚洲精品高清在线| 精品精品国产高清一毛片一天堂| 成人高清av在线| 精品一区二区三区视频| 一区二区欧美国产| 中文字幕一区二区三区四区不卡 | 91精品国产综合久久精品麻豆| 粉嫩在线一区二区三区视频| 免费久久精品视频| 亚洲成人在线免费| 亚洲在线观看免费视频| 欧美性视频一区二区三区| 在线观看视频一区| 成人久久视频在线观看| 九九国产精品视频| 美女在线观看视频一区二区| 亚洲一本大道在线| 亚洲主播在线观看| 五月天中文字幕一区二区| 一区二区免费在线播放| 亚洲女爱视频在线| 天堂一区二区在线| 婷婷夜色潮精品综合在线| 日本人妖一区二区| 九九久久精品视频| 国产精品亚洲视频| 成人免费电影视频| 在线欧美小视频| 成人黄页毛片网站| 成人免费电影视频| 在线综合+亚洲+欧美中文字幕| 精品国精品国产| 亚洲主播在线播放| 国产xxx精品视频大全|