質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.49%
Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Azure

Azureは、マイクロソフトのクラウド プラットフォームで、旧称は Windows Azureです。PaaSとIaaSを組み合わせることで、 コンピューティング・ストレージ・データ・ネットワーキング・アプリケーションなど多くの機能を持ちます。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

Q&A

解決済

2回答

1133閲覧

Azure Functions からNode.jsのhttpモジュールを使ってAPIをcallしたい

kkqskodoku

総合スコア20

Node.js

Node.jsとはGoogleのV8 JavaScriptエンジンを使用しているサーバーサイドのイベント駆動型プログラムです。

Azure

Azureは、マイクロソフトのクラウド プラットフォームで、旧称は Windows Azureです。PaaSとIaaSを組み合わせることで、 コンピューティング・ストレージ・データ・ネットワーキング・アプリケーションなど多くの機能を持ちます。

API

APIはApplication Programming Interfaceの略です。APIはプログラムにリクエストされるサービスがどのように動作するかを、デベロッパーが定めたものです。

0グッド

2クリップ

投稿2022/07/15 08:31

Azure およびNode.js ともに初心者です

使用環境

使用環境:Azure Functions
使用言語: Node.js

質問

Azure Functions からNode.jsのhttpモジュールを使用してAPIをcallするアプリを作成しています。
Qiitaのサンプル記事をもとに郵便番号検索APIをcallし、レスポンス値を加工する処理を作成しようとしましたが、
想定通りにhttpリクエストが実行されず困っています。
AzureとNode.jsのどちらも知識があまりなく、問題の切り分けができず。
AzureかNode.jsで確認すべき点や修正したほうがいい箇所がありましたら、ご指摘いただける助かります。

html

1const https = require('https'); 2const url = `https://zipcloud.ibsnet.co.jp/api/search?zipcode=7830060`; 3 const options = { 4 method: 'GET', 5 } 6 }; 7const client = https.request(url, options, (res) => { 8 context.log(res.statusCode); 9 context.log(res.headers); 10 let resBody = ''; 11 res.on('data', (chunk) => { resBody += chunk; }); 12 res.on('end', () => { 13 context.log(resBody); 14 context.res = {status: 204}; 15 context.done(); 16 }); 17 }); 18 client.on('error', (e) => { 19 context.log.error(e); 20 context.res = {status: 500}; 21 context.done(); 22 }); 23 client.end(); 24};

試したこと

①httpリクエスト処理の戻り値の変数をcontext.log()で表示
「request.undefined」が返ってくることを確認

②Azure FunctionsのKuduの実行ログを確認
Client Requestから始まる長い戻り値?が返ってきていることは確認しています。
確認点がわからず苦戦しています。

html

12022-07-ddThh:mm:ss.999 [Information] Client Request{ 2_events:[object: null prottype]{ 3 response:[Function:bound onceWrapper] 4--以下略--

コードサンプル

https://qiita.com/ma2shita/items/a9844a3a8e618600a109

###使用しているAPI
http://zipcloud.ibsnet.co.jp/doc/api

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kkqskodoku

2022/07/18 14:29

回答ありがとうございます。 アドバイスいただいた通り、「const options」を修正してみました。 ですが、最初の投稿と同じエラーが出続けます。 「contex.log」がAzureFunctionsのログおよびKUDUのログに出ていないため、 APIをCallできていないようだ…というところまでは推測できています。 ほかに確認したほうがいいことや、修正したほうがいい箇所がありましたらご指摘ください。
guest

回答2

0

こんにちは。

このソースコードが全文だとすると、構文エラーが起きていて実行時にエラーとなっているんじゃないかなと思います。const optionsのあたりです。
以下のように修正したところ実行出来ました。

module.exports = function (context, req) { const http = require('https'); const url = `https://zipcloud.ibsnet.co.jp/api/search?zipcode=7830060`; const options = { method: 'GET' }; const client = http.request(url, options, (res) => { context.log(res.statusCode); context.log(res.headers); let resBody = ''; res.on('data', (chunk) => { resBody += chunk; }); res.on('end', () => { context.log(resBody); context.res = {status: 204}; context.done(); }); }); client.on('error', (e) => { context.log.error(e); context.res = {status: 500}; context.done(); }); client.end(); };

投稿2022/07/17 03:51

Tak1wa

総合スコア4791

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

自己解決

本件、自己解決しました。
解決した流れは以下の通りです。
①Azure Functionsに新しく関数を作成
②参考もとのコードをコピペ
③呼び出し先APIのみ修正

知識が薄いので推測です。
Azure Functionsで「HTTP 要求に応答する JavaScript 関数」を起票するとサンプルコードを設定してくれるのですが、そのコードを残したまま追加コードを埋め込んだたため、想定通りの戻り値が返ってこなかったようです。

MS Docsリンク:https://docs.microsoft.com/ja-jp/azure/azure-functions/create-first-function-cli-node?tabs=azure-cli%2Cbrowser

投稿2022/07/22 02:27

kkqskodoku

総合スコア20

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.49%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問