
シェア:
Juliaは、チュートリアル、ガイド、実用的なリソースを作成することで、仲間の開発者に力を与えることに尽力しています。アウトリーチと教育のバックグラウンドを持つ彼女は、テクノロジーをより身近なものにし、開発者の経験全体を向上させることを目指しています。地域のコミュニティイベントでもよく見かける。
Node-REDでSMSメッセージを送信する方法
所要時間:3 分
注:この記事で説明されているツールや方法の中には、サポートが終了しているものや最新のものではないものがあります。最新の内容やサポートについては、最新の投稿をご確認いただくか、Vonage Community Slackの VonageコミュニティSlack
この記事は「VonageとNode-REDを始める」チュートリアルシリーズの第1回目です。
Vonage SMS APIを使用すると、シンプルなHTTPベースのAPIを使用して、世界中でSMSを送受信することができます。
朗報は、Node-REDパレットにNexmoノードが追加されたことで、このAPIや他の多くのAPIとのやり取りが簡単になったことだ。
この記事では、Node-REDでSMSメッセージを送信する方法を学びます。このフローは Node-REDライブラリからこのフローを入手するか、またはそれに従ってください。
前提条件
始める前に必要なものがいくつかある:
ングロク- でスピードアップ アーロンのブログ記事
資格の取得
Vonage API Account
To complete this tutorial, you will need a Vonage API account. If you don’t have one already, you can sign up today and start building with free credit. Once you have an account, you can find your API Key and API Secret at the top of the Vonage API Dashboard.
This tutorial also uses a virtual phone number. To purchase one, go to Numbers > Buy Numbers and search for one that meets your needs.
Vonage番号をレンタルせずにSMSを送信できる国もありますが、アメリカのようにSMSメッセージの発信元番号を所有する必要がある国もあります。
Node-REDエディタのセットアップ
まず インストールする必要があります。をインストールする必要がある。これは、ローカルマシン、シングルボードコンピュータ(Raspberry Piなど)、またはクラウドホスティングのいずれかの方法で行うことができます。この例ではローカルマシンを使いますので、Node-REDをグローバルにインストールしたら、ターミナルに以下のコマンドを入力してください。
Node-REDエディタにアクセスするには、ブラウザの http://localhost:1880.
エディタを開いたら、Nexmoノードをインストールする必要があります。インストールは パレットの管理メニューから node-red-contrib-nexmoパッケージを検索し、インストールをクリックします。
Install the Nexmo Node-RED package
これで、画面の左側に、デフォルトのノードに混じって、Nexmoのノードがすべて表示されるはずです。
Node-REDでSMSを送信する
その sendsmsノードまでスクロールし、それをワークスペースにドラッグする。これが今日のチュートリアルで重要な役割を果たします。
このノードをダブルクリックし、以下のパラメータを入力することで設定できます。以下の API KEYと API SECRETの横にある編集ボタンをクリックしてください。 Nexmo Credentials.
キー
説明
API KEY
APIキーは アカウント概要.
API SECRET
あなたのAPIシークレットは アカウント概要.
TO
E.164形式でSMSを送信する番号。例:447401234567
FROM
メッセージを表示する際に携帯電話に表示される番号またはテキスト。あなたは、この機能がサポートされている場合、あなたのブランドをよりよく表すために、カスタム英数字FROMを設定することができます あなたの国でサポートされている場合.
TEXT
メッセージの内容。自由に創造してください。'Hello World!'でもかまいません。
次に、フローに injectの入力として配線する。 sendsms.
これは非常に強力なもので、特定のペイロード値でフローを開始することができる。文字列、Numbers、ブーリアン、JavaScriptオブジェクト、またはフロー/グローバルコンテキスト値の注入をサポートしており、デフォルトとして1970年1月1日からのミリ秒単位の現在時刻のタイムスタンプを持っています。
ノードにすべてのパラメーターをハードコードしながら、単純にフローを開始するために使用することもできる。 sendsmsノードのすべてのパラメータをハードコードする。
の隣にある。 TO,FROMと TEXTの横に {}記号があります。 の横に記号があります。がサポートされていることを意味します。これは特定の値を動的に sendsmsノードに動的に特定の値を渡すときに便利です。
タイムスタンプが注入されることを知っているので、この値をメッセージ・テキストに追加してみよう。 {{msg.payload}}例えば
Hello World! The timestamp is `{{msg.payload}}`.SMSを送信するときに何が起こっているのかをもう少し詳しく知るには、'output'を sendsms出力を debugノードに配線してください。それをダブルクリックして Outputを complete msg object.
ヒット デプロイをクリックし injectSMSが届くはずです!
Sending an SMS in Node-RED
SMS API へのリクエストが成功すると、SMS API はメッセージオブジェクトの配列を返します。これらのオブジェクトはそれぞれ `status` が `0` で、メッセージの送信に成功したことを示し、その他に受信者番号、メッセージ ID、残金、料金、SMS 送信に使用するキャリアネットワークなどの詳細がいくつか含まれているのが理想的です。
このレスポンスオブジェクトは、Node-REDエディタの右側にあるデバッグエリアで見ることができます。
この出力を検査することは、SMS APIが何をしたかを判断するのに非常に役立つが、メッセージが受信者の端末に届いたという保証はない。
メッセージが配信されると、携帯電話会社から 配達受領書をVonageに返送します。これには配達状況が記載されています。
移動体通信事業者からの宅配便の受領について
送信メッセージの statusアウトバウンドメッセージを確認するには、ウェブフックエンドポイントを設定する必要があります。 配信レシートに転送する必要があります。
Webhookエンドポイントの定義
まず http入力ノードを http responseノードと debugノードに接続する。
入力ノードで http入力ノードで POSTを Methodとして選択し URLフィールドに /receipt.この http responseノードには 200として設定されているはずだ。 Status codeとして設定されているはずだが、これはデフォルト値でもあるので気にする必要はない。
Setting up a webhook for delivery receipts
ローカルサーバーをインターネットに公開する
次に、Vonageがアクセスできるように、ローカルサーバーをインターネットに公開する必要があります。これを行う便利な方法は、以下のようなトンネリングサービスを使うことだ。 ngrok.
ダウンロードをダウンロードし ngrokをダウンロードし、ターミナルで実行して、ポート 1880.
Starting an ngrok tunnel in a terminal window
あなたのローカルサーバーには、Webhookのエンドポイントとして使用できるngrok URLがあります。
Vonageでエンドポイントを設定する
最後のステップは、Vonage SMS APIに配信レシートの転送先を知らせることです。これは API設定の デフォルトSMS設定セクションで行います。
配信レシートのデフォルトのウェブフックURLを次のように設定します。 YOUR_NGROK_URL/receipt次に Save changes.
Delivery receipt endpoint URL in dashboard
これで、Node-REDエディターに戻って別のメッセージを送信すると、デバッグエリアに配信レシートが表示されます:
Delivery receipt in debug sidebar
その statusと err-codeパラメータはいずれもメッセージが正常に配信されたことを示します。配送受領ステータスメッセージとエラーコードの詳細については ドキュメント.
