成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

本地開發如何測試Webhook

開發 后端
Webhook 可用于外部系統通知你的系統發生了某個事件或更新。可能最知名的 Webhook 類型是支付服務提供商(PSP)通知你的系統支付狀態有了更新。

[[273544]]

 Webhook 可用于外部系統通知你的系統發生了某個事件或更新。可能最知名的 Webhook 類型是支付服務提供商(PSP)通知你的系統支付狀態有了更新。

它們通常以監聽的預定義 URL 的形式出現,例如 http://example.com/webhooks/payment-update。同時,另一個系統向該 URL 發送具有特定有效載荷的 POST 請求(例如支付 ID)。一旦請求進入,你就會獲得支付 ID,可以通過 PSP 的 API 用這個支付 ID 向它們詢問最新狀態,然后更新你的數據庫。

其他例子可以在這個對 Webhook 的出色的解釋中找到:https://sendgrid.com/blog/whats-webhook/

只要系統可通過互聯網公開訪問(這可能是你的生產環境或可公開訪問的臨時環境),測試這些 webhook 就相當順利。而當你在筆記本電腦上或虛擬機內部(例如,Vagrant 虛擬機)進行本地開發時,它就變得困難了。在這些情況下,發送 webhook 的一方無法公開訪問你的本地 URL。此外,監視發送的請求也很困難,這可能使開發和調試變得困難。

因此,這個例子將解決:

  • 測試來自本地開發環境的 webhook,該環境無法通過互聯網訪問。從服務器向 webhook 發送數據的服務無法訪問它。
  • 監控發送的請求和數據,以及應用程序生成的響應。這樣可以更輕松地進行調試,從而縮短開發周期。

前置需求:

  • 可選:如果你使用虛擬機(VM)進行開發,請確保它正在運行,并確保在 VM 中完成后續步驟。
  • 對于本教程,我們假設你定義了一個 vhost:webhook.example.vagrant。我在本教程中使用了 Vagrant VM,但你可以自由選擇 vhost。
  • 按照這個安裝說明安裝 ngrok。在 VM 中,我發現它的 Node 版本也很有用:https://www.npmjs.com/package/ngrok,但你可以隨意使用其他方法。

我假設你沒有在你的環境中運行 SSL,但如果你使用了,請將在下面的示例中的端口 80 替換為端口 433,http:// 替換為 https://

使 webhook 可測試

我們假設以下示例代碼。我將使用 PHP,但請將其視作偽代碼,因為我留下了一些關鍵部分(例如 API 密鑰、輸入驗證等)沒有編寫。

第一個文件:payment.php。此文件創建一個 $payment 對象,將其注冊到 PSP。然后它獲取客戶需要訪問的 URL,以便支付并將用戶重定向到客戶那里。

請注意,此示例中的 webhook.example.vagrant 是我們為開發設置定義的本地虛擬主機。它無法從外部世界進入。

  1. <?php
  2. /*
  3. * This file creates a payment and tells the PSP what webhook URL to use for updates
  4. * After creating the payment, we get a URL to send the customer to in order to pay at the PSP
  5. */
  6. $payment = [
  7. 'order_id' => 123,
  8. 'amount' => 25.00,
  9. 'description' => 'Test payment',
  10. 'redirect_url' => 'http://webhook.example.vagrant/redirect.php',
  11. 'webhook_url' => 'http://webhook.example.vagrant/webhook.php',
  12. ];
  13.  
  14. $payment = $paymentProvider->createPayment($payment);
  15. header("Location: " . $payment->getPaymentUrl());

第二個文件:webhook.php。此文件等待 PSP 調用以獲得有關更新的通知。

  1. <?php
  2. /*
  3. * This file gets called by the PSP and in the $_POST they submit an 'id'
  4. * We can use this ID to get the latest status from the PSP and update our internal systems afterward
  5. */
  6. $paymentId = $_POST['id'];
  7. $paymentInfo = $paymentProvider->getPayment($paymentId);
  8. $status = $paymentInfo->getStatus();
  9.  
  10. // Perform actions in here to update your system
  11. if ($status === 'paid') {
  12. ..
  13. }
  14. elseif ($status === 'cancelled') {
  15. ..
  16. }

我們的 webhook URL 無法通過互聯網訪問(請記住它:webhook.example.vagrant)。因此,PSP 永遠不可能調用文件 webhook.php,你的系統將永遠不會知道付款狀態,這最終導致訂單永遠不會被運送給客戶。

幸運的是,ngrok 可以解決這個問題。 ngrok 將自己描述為:

ngrok 通過安全隧道將 NAT 和防火墻后面的本地服務器暴露給公共互聯網。

讓我們為我們的項目啟動一個基本的隧道。在你的環境中(在你的系統上或在 VM 上)運行以下命令:

  1. ngrok http -host-header=rewrite webhook.example.vagrant:80

閱讀其文檔可以了解更多配置選項:https://ngrok.com/docs

會出現這樣的屏幕:

ngrok 輸出

我們剛剛做了什么?基本上,我們指示 ngrok 在端口 80 建立了一個到 http://webhook.example.vagrant 的隧道。同一個 URL 也可以通過 http://39741ffc.ngrok.iohttps://39741ffc.ngrok.io 訪問,它們能被任何知道此 URL 的人通過互聯網公開訪問。

請注意,你可以同時獲得 HTTP 和 HTTPS 兩個服務。這個文檔提供了如何將此限制為 HTTPS 的示例:https://ngrok.com/docs#bind-tls

那么,我們如何讓我們的 webhook 現在工作起來?將 payment.php 更新為以下代碼:

  1. <?php
  2. /*
  3. * This file creates a payment and tells the PSP what webhook URL to use for updates
  4. * After creating the payment, we get a URL to send the customer to in order to pay at the PSP
  5. */
  6. $payment = [
  7. 'order_id' => 123,
  8. 'amount' => 25.00,
  9. 'description' => 'Test payment',
  10. 'redirect_url' => 'http://webhook.example.vagrant/redirect.php',
  11. 'webhook_url' => 'https://39741ffc.ngrok.io/webhook.php',
  12. ];
  13.  
  14. $payment = $paymentProvider->createPayment($payment);
  15. header("Location: " . $payment->getPaymentUrl());

現在,我們告訴 PSP 通過 HTTPS 調用此隧道 URL。只要 PSP 通過隧道調用 webhook,ngrok 將確保使用未修改的有效負載調用內部 URL。

如何監控對 webhook 的調用?

你在上面看到的屏幕截圖概述了對隧道主機的調用,這些數據相當有限。幸運的是,ngrok 提供了一個非常好的儀表板,允許你檢查所有調用:

我不會深入研究這個問題,因為它是不言自明的,你只要運行它就行了。因此,我將解釋如何在 Vagrant 虛擬機上訪問它,因為它不是開箱即用的。

儀表板將允許你查看所有調用、其狀態代碼、標頭和發送的數據。你將看到應用程序生成的響應。

儀表板的另一個優點是它允許你重放某個調用。假設你的 webhook 代碼遇到了致命的錯誤,開始新的付款并等待 webhook 被調用將會很繁瑣。重放上一個調用可以使你的開發過程更快。

默認情況下,儀表板可在 http://localhost:4040 訪問。

虛擬機中的儀表盤

為了在 VM 中完成此工作,你必須執行一些額外的步驟:

首先,確保可以在端口 4040 上訪問 VM。然后,在 VM 內創建一個文件已存放此配置:

  1. web_addr: 0.0.0.0:4040

現在,殺死仍在運行的 ngrok 進程,并使用稍微調整過的命令啟動它:

  1. ngrok http -config=/path/to/config/ngrok.conf -host-header=rewrite webhook.example.vagrant:80

盡管 ID 已經更改,但你將看到類似于上一屏幕截圖的屏幕。之前的網址不再有效,但你有了一個新網址。 此外,Web Interface URL 已更改:

現在將瀏覽器指向 http://webhook.example.vagrant:4040 以訪問儀表板。另外,對 https://e65642b5.ngrok.io/webhook.php 做個調用。這可能會導致你的瀏覽器出錯,但儀表板應顯示正有一個請求。

最后的備注

上面的例子是偽代碼。原因是每個外部系統都以不同的方式使用 webhook。我試圖基于一個虛構的 PSP 實現給出一個例子,因為可能很多開發人員在某個時刻肯定會處理付款。

請注意,你的 webhook 網址也可能被意圖不好的其他人使用。確保驗證發送給它的任何輸入。

更好的的,可以向 URL 添加令牌,該令牌對于每個支付是唯一的。只有你的系統和發送 webhook 的系統才能知道此令牌。

祝你測試和調試你的 webhook 順利!

注意:我沒有在 Docker 上測試過本教程。但是,這個 Docker 容器看起來是一個很好的起點,并包含了明確的說明:https://github.com/wernight/docker-ngrok

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2023-11-27 13:41:00

Kubernete本地調試

2017-01-13 14:32:50

Azurewebhoo自動化AzureWebhook

2018-04-04 14:52:04

2016-10-28 08:39:23

WebHook運維工具

2023-10-07 08:49:56

測試驅動開發Xunit 框架

2011-05-30 17:11:08

測試策略

2011-06-24 16:19:59

QT web Webkit

2023-12-11 08:25:15

Java框架Android

2021-05-18 05:40:27

kubebuilderwebhook進階

2021-05-07 09:31:33

KindK8s Operator

2017-01-01 09:43:40

2011-05-26 17:28:48

軟件本地化測試

2011-09-23 09:46:09

軟件項目

2009-09-07 08:37:44

VMware測試和開發

2016-09-08 23:28:06

2010-10-12 09:17:42

本地代碼Native CodeNative Clie

2018-03-26 14:25:55

KubernetesSkaffold命令

2011-06-08 17:07:55

本地化測試

2023-04-24 13:37:04

Unity游戲開發

2020-05-20 08:57:14

JavaScript讀取文件開發
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久中文字幕一区 | 色av一区二区 | 在线免费观看黄色 | 免费看日韩视频 | 国产精品福利久久久 | 狠狠爱网址 | 蜜桃视频在线观看www社区 | 99久热在线精品视频观看 | 国产成在线观看免费视频 | 国产高清一区二区三区 | 午夜在线 | 激情欧美一区二区三区中文字幕 | 精品日韩一区二区 | caoporn国产精品免费公开 | 久久精品中文字幕 | 国产久 | 亚洲精美视频 | 国产精品小视频在线观看 | 亚洲1区 | 精品国产乱码久久久久久丨区2区 | 欧美色性| 天天躁日日躁狠狠很躁 | 日韩午夜激情 | 成人亚洲一区 | 亚洲欧洲精品一区 | 9porny九色视频自拍 | 国产精品欧美一区二区 | 色免费视频 | 日韩在线播放第一页 | 欧美色专区| 国产亚洲精品精品国产亚洲综合 | 欧美在线视频一区二区 | 欧美激情久久久 | 性欧美精品一区二区三区在线播放 | 美日韩免费视频 | 欲色av | 亚洲最大av | 免费观看一级特黄欧美大片 | 美女黄色在线观看 | 黄色一级片在线播放 | 伊人久久综合影院 |